@xyo-network/archivist-mongodb 2.75.0 → 2.75.3

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 (72) hide show
  1. package/dist/browser/Archivist.d.cts +239 -0
  2. package/dist/browser/Archivist.d.cts.map +1 -0
  3. package/dist/browser/Archivist.js +7 -72
  4. package/dist/browser/Archivist.js.map +1 -1
  5. package/dist/browser/index.d.cts +3 -0
  6. package/dist/browser/index.d.cts.map +1 -0
  7. package/dist/browser/index.js +1 -166
  8. package/dist/browser/index.js.map +1 -1
  9. package/dist/browser/lib/index.d.cts +5 -0
  10. package/dist/browser/lib/index.d.cts.map +1 -0
  11. package/dist/browser/lib/index.js +4 -70
  12. package/dist/browser/lib/index.js.map +1 -1
  13. package/dist/browser/lib/toBoundWitnessWithMeta.d.cts +5 -0
  14. package/dist/browser/lib/toBoundWitnessWithMeta.d.cts.map +1 -0
  15. package/dist/browser/lib/toBoundWitnessWithMeta.js +1 -3
  16. package/dist/browser/lib/toBoundWitnessWithMeta.js.map +1 -1
  17. package/dist/browser/lib/toPayloadWithMeta.d.cts +4 -0
  18. package/dist/browser/lib/toPayloadWithMeta.d.cts.map +1 -0
  19. package/dist/browser/lib/toPayloadWithMeta.js +1 -3
  20. package/dist/browser/lib/toPayloadWithMeta.js.map +1 -1
  21. package/dist/browser/lib/toReturnValue.d.cts +4 -0
  22. package/dist/browser/lib/toReturnValue.d.cts.map +1 -0
  23. package/dist/browser/lib/toReturnValue.js +1 -3
  24. package/dist/browser/lib/toReturnValue.js.map +1 -1
  25. package/dist/browser/lib/validByType.d.cts +11 -0
  26. package/dist/browser/lib/validByType.d.cts.map +1 -0
  27. package/dist/browser/lib/validByType.js +1 -3
  28. package/dist/browser/lib/validByType.js.map +1 -1
  29. package/dist/docs.json +32215 -0
  30. package/dist/node/Archivist.d.cts +239 -0
  31. package/dist/node/Archivist.d.cts.map +1 -0
  32. package/dist/node/Archivist.js +87 -18
  33. package/dist/node/Archivist.js.map +1 -1
  34. package/dist/node/Archivist.mjs +83 -14
  35. package/dist/node/Archivist.mjs.map +1 -1
  36. package/dist/node/index.d.cts +3 -0
  37. package/dist/node/index.d.cts.map +1 -0
  38. package/dist/node/index.js +176 -2
  39. package/dist/node/index.js.map +1 -1
  40. package/dist/node/index.mjs +170 -1
  41. package/dist/node/index.mjs.map +1 -1
  42. package/dist/node/lib/index.d.cts +5 -0
  43. package/dist/node/lib/index.d.cts.map +1 -0
  44. package/dist/node/lib/index.js +79 -9
  45. package/dist/node/lib/index.js.map +1 -1
  46. package/dist/node/lib/index.mjs +70 -4
  47. package/dist/node/lib/index.mjs.map +1 -1
  48. package/dist/node/lib/toBoundWitnessWithMeta.d.cts +5 -0
  49. package/dist/node/lib/toBoundWitnessWithMeta.d.cts.map +1 -0
  50. package/dist/node/lib/toBoundWitnessWithMeta.js +3 -1
  51. package/dist/node/lib/toBoundWitnessWithMeta.js.map +1 -1
  52. package/dist/node/lib/toBoundWitnessWithMeta.mjs +3 -1
  53. package/dist/node/lib/toBoundWitnessWithMeta.mjs.map +1 -1
  54. package/dist/node/lib/toPayloadWithMeta.d.cts +4 -0
  55. package/dist/node/lib/toPayloadWithMeta.d.cts.map +1 -0
  56. package/dist/node/lib/toPayloadWithMeta.js +3 -1
  57. package/dist/node/lib/toPayloadWithMeta.js.map +1 -1
  58. package/dist/node/lib/toPayloadWithMeta.mjs +3 -1
  59. package/dist/node/lib/toPayloadWithMeta.mjs.map +1 -1
  60. package/dist/node/lib/toReturnValue.d.cts +4 -0
  61. package/dist/node/lib/toReturnValue.d.cts.map +1 -0
  62. package/dist/node/lib/toReturnValue.js +4 -2
  63. package/dist/node/lib/toReturnValue.js.map +1 -1
  64. package/dist/node/lib/toReturnValue.mjs +4 -2
  65. package/dist/node/lib/toReturnValue.mjs.map +1 -1
  66. package/dist/node/lib/validByType.d.cts +11 -0
  67. package/dist/node/lib/validByType.d.cts.map +1 -0
  68. package/dist/node/lib/validByType.js +3 -1
  69. package/dist/node/lib/validByType.js.map +1 -1
  70. package/dist/node/lib/validByType.mjs +3 -1
  71. package/dist/node/lib/validByType.mjs.map +1 -1
  72. package/package.json +18 -18
@@ -0,0 +1,239 @@
1
+ import { AbstractArchivist } from '@xyo-network/archivist-abstract';
2
+ import { Payload } from '@xyo-network/payload-model';
3
+ declare const MongoDBArchivistBase: (abstract new (...args: any[]) => {
4
+ _boundWitnessSdk: import("@xyo-network/sdk-xyo-mongo-js").BaseMongoSdk<import("@xyo-network/node-core-model").BoundWitnessWithMeta> | undefined;
5
+ _payloadSdk: import("@xyo-network/sdk-xyo-mongo-js").BaseMongoSdk<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & import("@xyo-network/node-core-model").PayloadMetaBase & {
6
+ schema: string;
7
+ }> | undefined;
8
+ readonly boundWitnessSdkConfig: import("@xyo-network/sdk-xyo-mongo-js").BaseMongoSdkConfig;
9
+ readonly boundWitnesses: import("@xyo-network/sdk-xyo-mongo-js").BaseMongoSdk<import("@xyo-network/node-core-model").BoundWitnessWithMeta>;
10
+ readonly jobQueue: import("@xyo-network/node-core-model").JobQueue;
11
+ readonly payloadSdkConfig: import("@xyo-network/sdk-xyo-mongo-js").BaseMongoSdkConfig;
12
+ readonly payloads: import("@xyo-network/sdk-xyo-mongo-js").BaseMongoSdk<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & import("@xyo-network/node-core-model").PayloadMetaBase & {
13
+ schema: string;
14
+ }>;
15
+ address: string;
16
+ config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<{
17
+ accountDerivationPath?: string | undefined;
18
+ readonly archivist?: import("@xyo-network/module-model").ArchivistModuleConfig | undefined;
19
+ readonly labels?: import("@xyo-network/module-model").Labels | undefined;
20
+ readonly name?: string | undefined;
21
+ readonly paging?: Record<string, {
22
+ size?: number | undefined;
23
+ }> | undefined;
24
+ readonly security?: {
25
+ readonly allowAnonymous?: boolean | undefined;
26
+ readonly allowed?: Record<string, (string | import("@xyo-network/module-model").CosigningAddressSet)[]> | undefined;
27
+ readonly disallowed?: Record<string, string[]> | undefined;
28
+ } | undefined;
29
+ readonly sign?: boolean | undefined;
30
+ readonly storeQueries?: boolean | undefined;
31
+ readonly timestamp?: boolean | undefined;
32
+ } & Omit<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<{
33
+ accountDerivationPath?: string | undefined;
34
+ readonly archivist?: import("@xyo-network/module-model").ArchivistModuleConfig | undefined;
35
+ readonly labels?: import("@xyo-network/module-model").Labels | undefined;
36
+ readonly name?: string | undefined;
37
+ readonly paging?: Record<string, {
38
+ size?: number | undefined;
39
+ }> | undefined;
40
+ readonly security?: {
41
+ readonly allowAnonymous?: boolean | undefined;
42
+ readonly allowed?: Record<string, (string | import("@xyo-network/module-model").CosigningAddressSet)[]> | undefined;
43
+ readonly disallowed?: Record<string, string[]> | undefined;
44
+ } | undefined;
45
+ readonly sign?: boolean | undefined;
46
+ readonly storeQueries?: boolean | undefined;
47
+ readonly timestamp?: boolean | undefined;
48
+ } & {
49
+ boundWitnessSdkConfig?: Partial<import("@xyo-network/sdk-xyo-mongo-js").BaseMongoSdkPublicConfig> | undefined;
50
+ payloadSdkConfig?: Partial<import("@xyo-network/sdk-xyo-mongo-js").BaseMongoSdkPublicConfig> | undefined;
51
+ schema: "network.xyo.module.mongodb.config";
52
+ }, "schema"> & {
53
+ schema: "network.xyo.module.mongodb.config";
54
+ }, "schema"> & {
55
+ schema: string;
56
+ }, "schema"> & {
57
+ schema: string;
58
+ };
59
+ params: import("@xyo-network/core").BaseParamsFields & {
60
+ account?: import("@xyo-network/account-model").AccountInstance | "random" | undefined;
61
+ config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<{
62
+ accountDerivationPath?: string | undefined;
63
+ readonly archivist?: import("@xyo-network/module-model").ArchivistModuleConfig | undefined;
64
+ readonly labels?: import("@xyo-network/module-model").Labels | undefined;
65
+ readonly name?: string | undefined;
66
+ readonly paging?: Record<string, {
67
+ size?: number | undefined;
68
+ }> | undefined;
69
+ readonly security?: {
70
+ readonly allowAnonymous?: boolean | undefined;
71
+ readonly allowed?: Record<string, (string | import("@xyo-network/module-model").CosigningAddressSet)[]> | undefined;
72
+ readonly disallowed?: Record<string, string[]> | undefined;
73
+ } | undefined;
74
+ readonly sign?: boolean | undefined;
75
+ readonly storeQueries?: boolean | undefined;
76
+ readonly timestamp?: boolean | undefined;
77
+ } & Omit<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<{
78
+ accountDerivationPath?: string | undefined;
79
+ readonly archivist?: import("@xyo-network/module-model").ArchivistModuleConfig | undefined;
80
+ readonly labels?: import("@xyo-network/module-model").Labels | undefined;
81
+ readonly name?: string | undefined;
82
+ readonly paging?: Record<string, {
83
+ size?: number | undefined;
84
+ }> | undefined;
85
+ readonly security?: {
86
+ readonly allowAnonymous?: boolean | undefined;
87
+ readonly allowed?: Record<string, (string | import("@xyo-network/module-model").CosigningAddressSet)[]> | undefined;
88
+ readonly disallowed?: Record<string, string[]> | undefined;
89
+ } | undefined;
90
+ readonly sign?: boolean | undefined;
91
+ readonly storeQueries?: boolean | undefined;
92
+ readonly timestamp?: boolean | undefined;
93
+ } & {
94
+ boundWitnessSdkConfig?: Partial<import("@xyo-network/sdk-xyo-mongo-js").BaseMongoSdkPublicConfig> | undefined;
95
+ payloadSdkConfig?: Partial<import("@xyo-network/sdk-xyo-mongo-js").BaseMongoSdkPublicConfig> | undefined;
96
+ schema: "network.xyo.module.mongodb.config";
97
+ }, "schema"> & {
98
+ schema: "network.xyo.module.mongodb.config";
99
+ }, "schema"> & {
100
+ schema: string;
101
+ }, "schema"> & {
102
+ schema: string;
103
+ };
104
+ ephemeralQueryAccountEnabled?: boolean | undefined;
105
+ wallet?: import("@xyo-network/wallet-model").WalletInstance | undefined;
106
+ } & {
107
+ boundWitnessSdkConfig?: (import("@xyo-network/sdk-xyo-mongo-js").BaseMongoSdkPrivateConfig & Partial<import("@xyo-network/sdk-xyo-mongo-js").BaseMongoSdkPublicConfig>) | undefined;
108
+ jobQueue?: import("@xyo-network/node-core-model").JobQueue | undefined;
109
+ payloadSdkConfig?: (import("@xyo-network/sdk-xyo-mongo-js").BaseMongoSdkPrivateConfig & Partial<import("@xyo-network/sdk-xyo-mongo-js").BaseMongoSdkPublicConfig>) | undefined;
110
+ };
111
+ previousHash: () => import("@xyo-network/promise").Promisable<string | undefined, never>;
112
+ queries: string[];
113
+ query: <T extends import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/boundwitness-model").BoundWitnessFields & {
114
+ query: string;
115
+ resultSet?: string | undefined;
116
+ schema: "network.xyo.boundwitness";
117
+ }, "schema"> & {
118
+ schema: "network.xyo.boundwitness";
119
+ } = import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/boundwitness-model").BoundWitnessFields & {
120
+ query: string;
121
+ resultSet?: string | undefined;
122
+ schema: "network.xyo.boundwitness";
123
+ }, "schema"> & {
124
+ schema: "network.xyo.boundwitness";
125
+ }, TConf extends import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
126
+ accountDerivationPath?: string | undefined;
127
+ readonly archivist?: import("@xyo-network/module-model").ArchivistModuleConfig | undefined;
128
+ readonly labels?: import("@xyo-network/module-model").Labels | undefined;
129
+ readonly name?: string | undefined;
130
+ readonly paging?: Record<string, {
131
+ size?: number | undefined;
132
+ }> | undefined;
133
+ readonly security?: {
134
+ readonly allowAnonymous?: boolean | undefined;
135
+ readonly allowed?: Record<string, (string | import("@xyo-network/module-model").CosigningAddressSet)[]> | undefined;
136
+ readonly disallowed?: Record<string, string[]> | undefined;
137
+ } | undefined;
138
+ readonly sign?: boolean | undefined;
139
+ readonly storeQueries?: boolean | undefined;
140
+ readonly timestamp?: boolean | undefined;
141
+ } & {
142
+ schema: "network.xyo.module.config";
143
+ } = import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
144
+ accountDerivationPath?: string | undefined;
145
+ readonly archivist?: import("@xyo-network/module-model").ArchivistModuleConfig | undefined;
146
+ readonly labels?: import("@xyo-network/module-model").Labels | undefined;
147
+ readonly name?: string | undefined;
148
+ readonly paging?: Record<string, {
149
+ size?: number | undefined;
150
+ }> | undefined;
151
+ readonly security?: {
152
+ readonly allowAnonymous?: boolean | undefined;
153
+ readonly allowed?: Record<string, (string | import("@xyo-network/module-model").CosigningAddressSet)[]> | undefined;
154
+ readonly disallowed?: Record<string, string[]> | undefined;
155
+ } | undefined;
156
+ readonly sign?: boolean | undefined;
157
+ readonly storeQueries?: boolean | undefined;
158
+ readonly timestamp?: boolean | undefined;
159
+ } & {
160
+ schema: "network.xyo.module.config";
161
+ }>(query: T, payloads?: ({
162
+ schema: string;
163
+ } & import("@xyo-network/payload-model").PayloadFields)[] | undefined, queryConfig?: TConf | undefined) => import("@xyo-network/promise").Promisable<import("@xyo-network/module-model").ModuleQueryResult, never>;
164
+ queryable: <T_1 extends import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/boundwitness-model").BoundWitnessFields & {
165
+ query: string;
166
+ resultSet?: string | undefined;
167
+ schema: "network.xyo.boundwitness";
168
+ }, "schema"> & {
169
+ schema: "network.xyo.boundwitness";
170
+ } = import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/boundwitness-model").BoundWitnessFields & {
171
+ query: string;
172
+ resultSet?: string | undefined;
173
+ schema: "network.xyo.boundwitness";
174
+ }, "schema"> & {
175
+ schema: "network.xyo.boundwitness";
176
+ }, TConf_1 extends import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
177
+ accountDerivationPath?: string | undefined;
178
+ readonly archivist?: import("@xyo-network/module-model").ArchivistModuleConfig | undefined;
179
+ readonly labels?: import("@xyo-network/module-model").Labels | undefined;
180
+ readonly name?: string | undefined;
181
+ readonly paging?: Record<string, {
182
+ size?: number | undefined;
183
+ }> | undefined;
184
+ readonly security?: {
185
+ readonly allowAnonymous?: boolean | undefined;
186
+ readonly allowed?: Record<string, (string | import("@xyo-network/module-model").CosigningAddressSet)[]> | undefined;
187
+ readonly disallowed?: Record<string, string[]> | undefined;
188
+ } | undefined;
189
+ readonly sign?: boolean | undefined;
190
+ readonly storeQueries?: boolean | undefined;
191
+ readonly timestamp?: boolean | undefined;
192
+ } & {
193
+ schema: "network.xyo.module.config";
194
+ } = import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
195
+ accountDerivationPath?: string | undefined;
196
+ readonly archivist?: import("@xyo-network/module-model").ArchivistModuleConfig | undefined;
197
+ readonly labels?: import("@xyo-network/module-model").Labels | undefined;
198
+ readonly name?: string | undefined;
199
+ readonly paging?: Record<string, {
200
+ size?: number | undefined;
201
+ }> | undefined;
202
+ readonly security?: {
203
+ readonly allowAnonymous?: boolean | undefined;
204
+ readonly allowed?: Record<string, (string | import("@xyo-network/module-model").CosigningAddressSet)[]> | undefined;
205
+ readonly disallowed?: Record<string, string[]> | undefined;
206
+ } | undefined;
207
+ readonly sign?: boolean | undefined;
208
+ readonly storeQueries?: boolean | undefined;
209
+ readonly timestamp?: boolean | undefined;
210
+ } & {
211
+ schema: "network.xyo.module.config";
212
+ }>(query: T_1, payloads?: ({
213
+ schema: string;
214
+ } & import("@xyo-network/payload-model").PayloadFields)[] | undefined, queryConfig?: TConf_1 | undefined) => import("@xyo-network/promise").Promisable<boolean, never>;
215
+ start?: (() => import("@xyo-network/promise").Promisable<boolean, never>) | undefined;
216
+ stop?: (() => import("@xyo-network/promise").Promisable<boolean, never>) | undefined;
217
+ eventData: import("@xyo-network/module-model").ModuleEventData<object>;
218
+ clearListeners(eventNames: keyof import("@xyo-network/module-model").ModuleEventData<object> | (keyof import("@xyo-network/module-model").ModuleEventData<object>)[]): void;
219
+ emit<TEventName extends keyof import("@xyo-network/module-model").ModuleEventData<object>>(eventName: TEventName, eventArgs: import("@xyo-network/module-model").ModuleEventData<object>[TEventName]): Promise<void>;
220
+ emitSerial<TEventName_1 extends keyof import("@xyo-network/module-model").ModuleEventData<object>>(eventName: TEventName_1, eventArgs: import("@xyo-network/module-model").ModuleEventData<object>[TEventName_1]): Promise<void>;
221
+ listenerCount(eventNames: keyof import("@xyo-network/module-model").ModuleEventData<object> | (keyof import("@xyo-network/module-model").ModuleEventData<object>)[]): number;
222
+ off<TEventName_2 extends keyof import("@xyo-network/module-model").ModuleEventData<object>>(eventNames: TEventName_2 | TEventName_2[], listener: import("@xyo-network/module-events").EventListener<import("@xyo-network/module-model").ModuleEventData<object>[TEventName_2]>): void;
223
+ offAny(listener: Promise<void> | import("@xyo-network/module-events").EventAnyListener<import("@xyo-network/module-events").EventArgs>): void;
224
+ on<TEventName_3 extends keyof import("@xyo-network/module-model").ModuleEventData<object>>(eventNames: TEventName_3 | TEventName_3[], listener: import("@xyo-network/module-events").EventListener<import("@xyo-network/module-model").ModuleEventData<object>[TEventName_3]>): import("@xyo-network/module-events").EventUnsubscribeFunction;
225
+ onAny(listener: import("@xyo-network/module-events").EventAnyListener<import("@xyo-network/module-events").EventArgs>): import("@xyo-network/module-events").EventUnsubscribeFunction;
226
+ once<TEventName_4 extends keyof import("@xyo-network/module-model").ModuleEventData<object>>(eventName: TEventName_4, listener: import("@xyo-network/module-events").EventListener<import("@xyo-network/module-model").ModuleEventData<object>[TEventName_4]>): import("@xyo-network/module-events").EventUnsubscribeFunction;
227
+ }) & {
228
+ labels: import("@xyo-network/module-model-mongodb").MongoDBStorageClassLabels;
229
+ } & typeof AbstractArchivist;
230
+ export declare class MongoDBArchivist extends MongoDBArchivistBase {
231
+ static configSchemas: string[];
232
+ readonly queries: string[];
233
+ head(): Promise<Payload | undefined>;
234
+ protected getHandler(hashes: string[]): Promise<Payload[]>;
235
+ protected insertHandler(payloads?: Payload[]): Promise<Payload[]>;
236
+ protected startHandler(): Promise<boolean>;
237
+ }
238
+ export {};
239
+ //# sourceMappingURL=Archivist.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Archivist.d.ts","sourceRoot":"","sources":["../../src/Archivist.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAKnE,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AA0BpD,QAAA,MAAM,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAwC,CAAA;AAElE,qBAAa,gBAAiB,SAAQ,oBAAoB;IACxD,OAAgB,aAAa,WAAwD;IAErF,SAAkB,OAAO,EAAE,MAAM,EAAE,CAAiD;IAErE,IAAI,IAAI,OAAO,CAAC,OAAO,GAAG,SAAS,CAAC;cAK1B,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;cAQhD,aAAa,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;cAiBvD,YAAY;CActC"}
@@ -3,6 +3,7 @@ var __defProp = Object.defineProperty;
3
3
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
5
5
  var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
6
7
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
7
8
  var __export = (target, all) => {
8
9
  for (var name in all)
@@ -17,6 +18,12 @@ var __copyProps = (to, from, except, desc) => {
17
18
  return to;
18
19
  };
19
20
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
21
+ var __publicField = (obj, key, value) => {
22
+ __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
23
+ return value;
24
+ };
25
+
26
+ // src/Archivist.ts
20
27
  var Archivist_exports = {};
21
28
  __export(Archivist_exports, {
22
29
  MongoDBArchivist: () => MongoDBArchivist
@@ -28,9 +35,72 @@ var import_archivist_abstract = require("@xyo-network/archivist-abstract");
28
35
  var import_archivist_model = require("@xyo-network/archivist-model");
29
36
  var import_archivist_model_mongodb = require("@xyo-network/archivist-model-mongodb");
30
37
  var import_module_abstract_mongodb = require("@xyo-network/module-abstract-mongodb");
38
+ var import_payload_wrapper3 = require("@xyo-network/payload-wrapper");
39
+
40
+ // src/lib/toBoundWitnessWithMeta.ts
41
+ var toBoundWitnessWithMeta = /* @__PURE__ */ __name(async (wrapper) => {
42
+ const bw = wrapper.boundwitness;
43
+ return {
44
+ ...bw,
45
+ _hash: await wrapper.hashAsync(),
46
+ _timestamp: Date.now()
47
+ };
48
+ }, "toBoundWitnessWithMeta");
49
+
50
+ // src/lib/toPayloadWithMeta.ts
51
+ var toPayloadWithMeta = /* @__PURE__ */ __name(async (wrapper) => {
52
+ return {
53
+ ...wrapper.payload(),
54
+ _hash: await wrapper.hashAsync(),
55
+ _timestamp: Date.now()
56
+ };
57
+ }, "toPayloadWithMeta");
58
+
59
+ // src/lib/toReturnValue.ts
31
60
  var import_payload_wrapper = require("@xyo-network/payload-wrapper");
32
- var import_lib = require("./lib");
33
- const getBoundWitnessesIndexes = /* @__PURE__ */ __name((collectionName) => {
61
+ var toReturnValue = /* @__PURE__ */ __name((value) => {
62
+ const _signatures = value == null ? void 0 : value._signatures;
63
+ if (_signatures) {
64
+ return {
65
+ ...import_payload_wrapper.PayloadWrapper.wrap(value).body(),
66
+ _signatures
67
+ };
68
+ } else {
69
+ return {
70
+ ...import_payload_wrapper.PayloadWrapper.wrap(value).body()
71
+ };
72
+ }
73
+ }, "toReturnValue");
74
+
75
+ // src/lib/validByType.ts
76
+ var import_boundwitness_builder = require("@xyo-network/boundwitness-builder");
77
+ var import_boundwitness_model = require("@xyo-network/boundwitness-model");
78
+ var import_boundwitness_wrapper = require("@xyo-network/boundwitness-wrapper");
79
+ var import_payload_wrapper2 = require("@xyo-network/payload-wrapper");
80
+ var validByType = /* @__PURE__ */ __name(async (payloads = []) => {
81
+ const results = [
82
+ [],
83
+ []
84
+ ];
85
+ await Promise.all(payloads.map(async (payload) => {
86
+ if ((0, import_boundwitness_model.isBoundWitness)(payload)) {
87
+ const wrapper = (0, import_boundwitness_builder.isQueryBoundWitness)(payload) ? import_boundwitness_builder.QueryBoundWitnessWrapper : import_boundwitness_wrapper.BoundWitnessWrapper;
88
+ const bw = wrapper.parse(payload);
89
+ if (await bw.getValid()) {
90
+ results[0].push(bw);
91
+ }
92
+ } else {
93
+ const payloadWrapper = import_payload_wrapper2.PayloadWrapper.wrap(payload);
94
+ if (await payloadWrapper.getValid()) {
95
+ results[1].push(payloadWrapper);
96
+ }
97
+ }
98
+ }));
99
+ return results;
100
+ }, "validByType");
101
+
102
+ // src/Archivist.ts
103
+ var getBoundWitnessesIndexes = /* @__PURE__ */ __name((collectionName) => {
34
104
  return [
35
105
  {
36
106
  // eslint-disable-next-line sort-keys-fix/sort-keys-fix
@@ -41,7 +111,7 @@ const getBoundWitnessesIndexes = /* @__PURE__ */ __name((collectionName) => {
41
111
  }
42
112
  ];
43
113
  }, "getBoundWitnessesIndexes");
44
- const getPayloadsIndexes = /* @__PURE__ */ __name((collectionName) => {
114
+ var getPayloadsIndexes = /* @__PURE__ */ __name((collectionName) => {
45
115
  return [
46
116
  {
47
117
  // eslint-disable-next-line sort-keys-fix/sort-keys-fix
@@ -52,15 +122,8 @@ const getPayloadsIndexes = /* @__PURE__ */ __name((collectionName) => {
52
122
  }
53
123
  ];
54
124
  }, "getPayloadsIndexes");
55
- const MongoDBArchivistBase = (0, import_module_abstract_mongodb.MongoDBModuleMixin)(import_archivist_abstract.AbstractArchivist);
56
- class MongoDBArchivist extends MongoDBArchivistBase {
57
- static {
58
- __name(this, "MongoDBArchivist");
59
- }
60
- static configSchemas = [
61
- import_archivist_model_mongodb.MongoDBArchivistConfigSchema,
62
- import_archivist_model.ArchivistConfigSchema
63
- ];
125
+ var MongoDBArchivistBase = (0, import_module_abstract_mongodb.MongoDBModuleMixin)(import_archivist_abstract.AbstractArchivist);
126
+ var _MongoDBArchivist = class _MongoDBArchivist extends MongoDBArchivistBase {
64
127
  queries = [
65
128
  import_archivist_model.ArchivistInsertQuerySchema,
66
129
  ...super.queries
@@ -69,7 +132,7 @@ class MongoDBArchivist extends MongoDBArchivistBase {
69
132
  const head = await (await this.payloads.find({})).sort({
70
133
  _timestamp: -1
71
134
  }).limit(1).toArray();
72
- return head[0] ? import_payload_wrapper.PayloadWrapper.wrap(head[0]).body() : void 0;
135
+ return head[0] ? import_payload_wrapper3.PayloadWrapper.wrap(head[0]).body() : void 0;
73
136
  }
74
137
  async getHandler(hashes) {
75
138
  const payloads = hashes.map((_hash) => this.payloads.findOne({
@@ -83,12 +146,12 @@ class MongoDBArchivist extends MongoDBArchivistBase {
83
146
  bws
84
147
  ].flat());
85
148
  const succeeded = gets.reduce(import_promise.fulfilledValues, []);
86
- return succeeded.filter(import_exists.exists).map(import_lib.toReturnValue);
149
+ return succeeded.filter(import_exists.exists).map(toReturnValue);
87
150
  }
88
151
  async insertHandler(payloads) {
89
- const [bw, p] = await (0, import_lib.validByType)(payloads);
90
- const boundWitnesses = await Promise.all(bw.map((x) => (0, import_lib.toBoundWitnessWithMeta)(x)));
91
- const payloadsWithMeta = await Promise.all(p.map((x) => (0, import_lib.toPayloadWithMeta)(x)));
152
+ const [bw, p] = await validByType(payloads);
153
+ const boundWitnesses = await Promise.all(bw.map((x) => toBoundWitnessWithMeta(x)));
154
+ const payloadsWithMeta = await Promise.all(p.map((x) => toPayloadWithMeta(x)));
92
155
  if (boundWitnesses.length) {
93
156
  const boundWitnessesResult = await this.boundWitnesses.insertMany(boundWitnesses);
94
157
  if (!boundWitnessesResult.acknowledged || boundWitnessesResult.insertedCount !== boundWitnesses.length)
@@ -115,7 +178,13 @@ class MongoDBArchivist extends MongoDBArchivistBase {
115
178
  });
116
179
  return true;
117
180
  }
118
- }
181
+ };
182
+ __name(_MongoDBArchivist, "MongoDBArchivist");
183
+ __publicField(_MongoDBArchivist, "configSchemas", [
184
+ import_archivist_model_mongodb.MongoDBArchivistConfigSchema,
185
+ import_archivist_model.ArchivistConfigSchema
186
+ ]);
187
+ var MongoDBArchivist = _MongoDBArchivist;
119
188
  // Annotate the CommonJS export names for ESM import in node:
120
189
  0 && (module.exports = {
121
190
  MongoDBArchivist
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Archivist.ts"],"sourcesContent":["import { exists } from '@xylabs/exists'\nimport { fulfilledValues } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport { ArchivistConfigSchema, ArchivistInsertQuerySchema } from '@xyo-network/archivist-model'\nimport { MongoDBArchivistConfigSchema } from '@xyo-network/archivist-model-mongodb'\nimport { CollectionIndexFunction, MongoDBModuleMixin } from '@xyo-network/module-abstract-mongodb'\nimport { PayloadWithPartialMeta } from '@xyo-network/node-core-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\nimport { IndexDescription } from 'mongodb'\n\nimport { toBoundWitnessWithMeta, toPayloadWithMeta, toReturnValue, validByType } from './lib'\n\nconst getBoundWitnessesIndexes: CollectionIndexFunction = (collectionName: string): IndexDescription[] => {\n return [\n {\n // eslint-disable-next-line sort-keys-fix/sort-keys-fix\n key: { _hash: 1 },\n name: `${collectionName}.IX__hash`,\n },\n ]\n}\n\nconst getPayloadsIndexes: CollectionIndexFunction = (collectionName: string): IndexDescription[] => {\n return [\n {\n // eslint-disable-next-line sort-keys-fix/sort-keys-fix\n key: { _hash: 1 },\n name: `${collectionName}.IX__hash`,\n },\n ]\n}\n\nconst MongoDBArchivistBase = MongoDBModuleMixin(AbstractArchivist)\n\nexport class MongoDBArchivist extends MongoDBArchivistBase {\n static override configSchemas = [MongoDBArchivistConfigSchema, ArchivistConfigSchema]\n\n override readonly queries: string[] = [ArchivistInsertQuerySchema, ...super.queries]\n\n override async head(): Promise<Payload | undefined> {\n const head = await (await this.payloads.find({})).sort({ _timestamp: -1 }).limit(1).toArray()\n return head[0] ? PayloadWrapper.wrap(head[0]).body() : undefined\n }\n\n protected override async getHandler(hashes: string[]): Promise<Payload[]> {\n const payloads = hashes.map((_hash) => this.payloads.findOne({ _hash }))\n const bws = hashes.map((_hash) => this.boundWitnesses.findOne({ _hash }))\n const gets = await Promise.allSettled([payloads, bws].flat())\n const succeeded = gets.reduce<(PayloadWithPartialMeta | null)[]>(fulfilledValues, []) as Payload[]\n return succeeded.filter(exists).map(toReturnValue)\n }\n\n protected override async insertHandler(payloads?: Payload[]): Promise<Payload[]> {\n const [bw, p] = await validByType(payloads)\n const boundWitnesses = await Promise.all(bw.map((x) => toBoundWitnessWithMeta(x)))\n const payloadsWithMeta = await Promise.all(p.map((x) => toPayloadWithMeta(x)))\n if (boundWitnesses.length) {\n const boundWitnessesResult = await this.boundWitnesses.insertMany(boundWitnesses)\n if (!boundWitnessesResult.acknowledged || boundWitnessesResult.insertedCount !== boundWitnesses.length)\n throw new Error('MongoDBDeterministicArchivist: Error inserting BoundWitnesses')\n }\n if (payloadsWithMeta.length) {\n const payloadsResult = await this.payloads.insertMany(payloadsWithMeta)\n if (!payloadsResult.acknowledged || payloadsResult.insertedCount !== payloadsWithMeta.length)\n throw new Error('MongoDBDeterministicArchivist: Error inserting Payloads')\n }\n return payloads ?? []\n }\n\n protected override async startHandler() {\n await super.startHandler()\n await this.boundWitnesses.useCollection(async (collection) => {\n const { collectionName } = collection\n const indexes = getBoundWitnessesIndexes(collectionName)\n await collection.createIndexes(indexes)\n })\n await this.payloads.useCollection(async (collection) => {\n const { collectionName } = collection\n const indexes = getPayloadsIndexes(collectionName)\n await collection.createIndexes(indexes)\n })\n return true\n }\n}\n"],"mappings":"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","names":["getBoundWitnessesIndexes","collectionName","key","_hash","name","getPayloadsIndexes","MongoDBArchivistBase","MongoDBModuleMixin","AbstractArchivist","MongoDBArchivist","configSchemas","MongoDBArchivistConfigSchema","ArchivistConfigSchema","queries","ArchivistInsertQuerySchema","head","payloads","find","sort","_timestamp","limit","toArray","PayloadWrapper","wrap","body","undefined","getHandler","hashes","map","findOne","bws","boundWitnesses","gets","Promise","allSettled","flat","succeeded","reduce","fulfilledValues","filter","exists","toReturnValue","insertHandler","bw","p","validByType","all","x","toBoundWitnessWithMeta","payloadsWithMeta","toPayloadWithMeta","length","boundWitnessesResult","insertMany","acknowledged","insertedCount","Error","payloadsResult","startHandler","useCollection","collection","indexes","createIndexes"]}
1
+ {"version":3,"sources":["../../src/Archivist.ts","../../src/lib/toBoundWitnessWithMeta.ts","../../src/lib/toPayloadWithMeta.ts","../../src/lib/toReturnValue.ts","../../src/lib/validByType.ts"],"sourcesContent":["import { exists } from '@xylabs/exists'\nimport { fulfilledValues } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport { ArchivistConfigSchema, ArchivistInsertQuerySchema } from '@xyo-network/archivist-model'\nimport { MongoDBArchivistConfigSchema } from '@xyo-network/archivist-model-mongodb'\nimport { CollectionIndexFunction, MongoDBModuleMixin } from '@xyo-network/module-abstract-mongodb'\nimport { PayloadWithPartialMeta } from '@xyo-network/node-core-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\nimport { IndexDescription } from 'mongodb'\n\nimport { toBoundWitnessWithMeta, toPayloadWithMeta, toReturnValue, validByType } from './lib'\n\nconst getBoundWitnessesIndexes: CollectionIndexFunction = (collectionName: string): IndexDescription[] => {\n return [\n {\n // eslint-disable-next-line sort-keys-fix/sort-keys-fix\n key: { _hash: 1 },\n name: `${collectionName}.IX__hash`,\n },\n ]\n}\n\nconst getPayloadsIndexes: CollectionIndexFunction = (collectionName: string): IndexDescription[] => {\n return [\n {\n // eslint-disable-next-line sort-keys-fix/sort-keys-fix\n key: { _hash: 1 },\n name: `${collectionName}.IX__hash`,\n },\n ]\n}\n\nconst MongoDBArchivistBase = MongoDBModuleMixin(AbstractArchivist)\n\nexport class MongoDBArchivist extends MongoDBArchivistBase {\n static override configSchemas = [MongoDBArchivistConfigSchema, ArchivistConfigSchema]\n\n override readonly queries: string[] = [ArchivistInsertQuerySchema, ...super.queries]\n\n override async head(): Promise<Payload | undefined> {\n const head = await (await this.payloads.find({})).sort({ _timestamp: -1 }).limit(1).toArray()\n return head[0] ? PayloadWrapper.wrap(head[0]).body() : undefined\n }\n\n protected override async getHandler(hashes: string[]): Promise<Payload[]> {\n const payloads = hashes.map((_hash) => this.payloads.findOne({ _hash }))\n const bws = hashes.map((_hash) => this.boundWitnesses.findOne({ _hash }))\n const gets = await Promise.allSettled([payloads, bws].flat())\n const succeeded = gets.reduce<(PayloadWithPartialMeta | null)[]>(fulfilledValues, []) as Payload[]\n return succeeded.filter(exists).map(toReturnValue)\n }\n\n protected override async insertHandler(payloads?: Payload[]): Promise<Payload[]> {\n const [bw, p] = await validByType(payloads)\n const boundWitnesses = await Promise.all(bw.map((x) => toBoundWitnessWithMeta(x)))\n const payloadsWithMeta = await Promise.all(p.map((x) => toPayloadWithMeta(x)))\n if (boundWitnesses.length) {\n const boundWitnessesResult = await this.boundWitnesses.insertMany(boundWitnesses)\n if (!boundWitnessesResult.acknowledged || boundWitnessesResult.insertedCount !== boundWitnesses.length)\n throw new Error('MongoDBDeterministicArchivist: Error inserting BoundWitnesses')\n }\n if (payloadsWithMeta.length) {\n const payloadsResult = await this.payloads.insertMany(payloadsWithMeta)\n if (!payloadsResult.acknowledged || payloadsResult.insertedCount !== payloadsWithMeta.length)\n throw new Error('MongoDBDeterministicArchivist: Error inserting Payloads')\n }\n return payloads ?? []\n }\n\n protected override async startHandler() {\n await super.startHandler()\n await this.boundWitnesses.useCollection(async (collection) => {\n const { collectionName } = collection\n const indexes = getBoundWitnessesIndexes(collectionName)\n await collection.createIndexes(indexes)\n })\n await this.payloads.useCollection(async (collection) => {\n const { collectionName } = collection\n const indexes = getPayloadsIndexes(collectionName)\n await collection.createIndexes(indexes)\n })\n return true\n }\n}\n","import { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { BoundWitnessWithMeta } from '@xyo-network/node-core-model'\n\nexport const toBoundWitnessWithMeta = async (wrapper: BoundWitnessWrapper | QueryBoundWitnessWrapper): Promise<BoundWitnessWithMeta> => {\n const bw = wrapper.boundwitness as BoundWitness\n return { ...bw, _hash: await wrapper.hashAsync(), _timestamp: Date.now() }\n}\n","import { PayloadWithMeta } from '@xyo-network/node-core-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nexport const toPayloadWithMeta = async (wrapper: PayloadWrapper): Promise<PayloadWithMeta> => {\n return { ...wrapper.payload(), _hash: await wrapper.hashAsync(), _timestamp: Date.now() }\n}\n","import { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nexport const toReturnValue = (value: Payload | BoundWitness): Payload => {\n const _signatures = (value as BoundWitness)?._signatures\n if (_signatures) {\n return { ...PayloadWrapper.wrap(value).body(), _signatures } as BoundWitness\n } else {\n return { ...PayloadWrapper.wrap(value).body() }\n }\n}\n","import { isQueryBoundWitness, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nexport const validByType = async (payloads: Payload[] = []) => {\n const results: [BoundWitnessWrapper[], PayloadWrapper[]] = [[], []]\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(bw)\n }\n } else {\n const payloadWrapper = PayloadWrapper.wrap(payload)\n if (await payloadWrapper.getValid()) {\n results[1].push(payloadWrapper)\n }\n }\n }),\n )\n return results\n}\n"],"mappings":"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","names":["import_payload_wrapper","toBoundWitnessWithMeta","wrapper","bw","boundwitness","_hash","hashAsync","_timestamp","Date","now","toPayloadWithMeta","wrapper","payload","_hash","hashAsync","_timestamp","Date","now","toReturnValue","value","_signatures","PayloadWrapper","wrap","body","import_payload_wrapper","validByType","payloads","results","Promise","all","map","payload","isBoundWitness","wrapper","isQueryBoundWitness","QueryBoundWitnessWrapper","BoundWitnessWrapper","bw","parse","getValid","push","payloadWrapper","PayloadWrapper","wrap","getBoundWitnessesIndexes","collectionName","key","_hash","name","getPayloadsIndexes","MongoDBArchivistBase","MongoDBModuleMixin","AbstractArchivist","MongoDBArchivist","queries","ArchivistInsertQuerySchema","head","payloads","find","sort","_timestamp","limit","toArray","PayloadWrapper","wrap","body","undefined","getHandler","hashes","map","findOne","bws","boundWitnesses","gets","Promise","allSettled","flat","succeeded","reduce","fulfilledValues","filter","exists","toReturnValue","insertHandler","bw","p","validByType","all","x","toBoundWitnessWithMeta","payloadsWithMeta","toPayloadWithMeta","length","boundWitnessesResult","insertMany","acknowledged","insertedCount","Error","payloadsResult","startHandler","useCollection","collection","indexes","createIndexes","configSchemas","MongoDBArchivistConfigSchema","ArchivistConfigSchema"]}
@@ -1,14 +1,84 @@
1
1
  var __defProp = Object.defineProperty;
2
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
2
3
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
4
+ var __publicField = (obj, key, value) => {
5
+ __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
6
+ return value;
7
+ };
8
+
9
+ // src/Archivist.ts
3
10
  import { exists } from "@xylabs/exists";
4
11
  import { fulfilledValues } from "@xylabs/promise";
5
12
  import { AbstractArchivist } from "@xyo-network/archivist-abstract";
6
13
  import { ArchivistConfigSchema, ArchivistInsertQuerySchema } from "@xyo-network/archivist-model";
7
14
  import { MongoDBArchivistConfigSchema } from "@xyo-network/archivist-model-mongodb";
8
15
  import { MongoDBModuleMixin } from "@xyo-network/module-abstract-mongodb";
16
+ import { PayloadWrapper as PayloadWrapper3 } from "@xyo-network/payload-wrapper";
17
+
18
+ // src/lib/toBoundWitnessWithMeta.ts
19
+ var toBoundWitnessWithMeta = /* @__PURE__ */ __name(async (wrapper) => {
20
+ const bw = wrapper.boundwitness;
21
+ return {
22
+ ...bw,
23
+ _hash: await wrapper.hashAsync(),
24
+ _timestamp: Date.now()
25
+ };
26
+ }, "toBoundWitnessWithMeta");
27
+
28
+ // src/lib/toPayloadWithMeta.ts
29
+ var toPayloadWithMeta = /* @__PURE__ */ __name(async (wrapper) => {
30
+ return {
31
+ ...wrapper.payload(),
32
+ _hash: await wrapper.hashAsync(),
33
+ _timestamp: Date.now()
34
+ };
35
+ }, "toPayloadWithMeta");
36
+
37
+ // src/lib/toReturnValue.ts
9
38
  import { PayloadWrapper } from "@xyo-network/payload-wrapper";
10
- import { toBoundWitnessWithMeta, toPayloadWithMeta, toReturnValue, validByType } from "./lib";
11
- const getBoundWitnessesIndexes = /* @__PURE__ */ __name((collectionName) => {
39
+ var toReturnValue = /* @__PURE__ */ __name((value) => {
40
+ const _signatures = value == null ? void 0 : value._signatures;
41
+ if (_signatures) {
42
+ return {
43
+ ...PayloadWrapper.wrap(value).body(),
44
+ _signatures
45
+ };
46
+ } else {
47
+ return {
48
+ ...PayloadWrapper.wrap(value).body()
49
+ };
50
+ }
51
+ }, "toReturnValue");
52
+
53
+ // src/lib/validByType.ts
54
+ import { isQueryBoundWitness, QueryBoundWitnessWrapper } from "@xyo-network/boundwitness-builder";
55
+ import { isBoundWitness } from "@xyo-network/boundwitness-model";
56
+ import { BoundWitnessWrapper } from "@xyo-network/boundwitness-wrapper";
57
+ import { PayloadWrapper as PayloadWrapper2 } from "@xyo-network/payload-wrapper";
58
+ var validByType = /* @__PURE__ */ __name(async (payloads = []) => {
59
+ const results = [
60
+ [],
61
+ []
62
+ ];
63
+ await Promise.all(payloads.map(async (payload) => {
64
+ if (isBoundWitness(payload)) {
65
+ const wrapper = isQueryBoundWitness(payload) ? QueryBoundWitnessWrapper : BoundWitnessWrapper;
66
+ const bw = wrapper.parse(payload);
67
+ if (await bw.getValid()) {
68
+ results[0].push(bw);
69
+ }
70
+ } else {
71
+ const payloadWrapper = PayloadWrapper2.wrap(payload);
72
+ if (await payloadWrapper.getValid()) {
73
+ results[1].push(payloadWrapper);
74
+ }
75
+ }
76
+ }));
77
+ return results;
78
+ }, "validByType");
79
+
80
+ // src/Archivist.ts
81
+ var getBoundWitnessesIndexes = /* @__PURE__ */ __name((collectionName) => {
12
82
  return [
13
83
  {
14
84
  // eslint-disable-next-line sort-keys-fix/sort-keys-fix
@@ -19,7 +89,7 @@ const getBoundWitnessesIndexes = /* @__PURE__ */ __name((collectionName) => {
19
89
  }
20
90
  ];
21
91
  }, "getBoundWitnessesIndexes");
22
- const getPayloadsIndexes = /* @__PURE__ */ __name((collectionName) => {
92
+ var getPayloadsIndexes = /* @__PURE__ */ __name((collectionName) => {
23
93
  return [
24
94
  {
25
95
  // eslint-disable-next-line sort-keys-fix/sort-keys-fix
@@ -30,15 +100,8 @@ const getPayloadsIndexes = /* @__PURE__ */ __name((collectionName) => {
30
100
  }
31
101
  ];
32
102
  }, "getPayloadsIndexes");
33
- const MongoDBArchivistBase = MongoDBModuleMixin(AbstractArchivist);
34
- class MongoDBArchivist extends MongoDBArchivistBase {
35
- static {
36
- __name(this, "MongoDBArchivist");
37
- }
38
- static configSchemas = [
39
- MongoDBArchivistConfigSchema,
40
- ArchivistConfigSchema
41
- ];
103
+ var MongoDBArchivistBase = MongoDBModuleMixin(AbstractArchivist);
104
+ var _MongoDBArchivist = class _MongoDBArchivist extends MongoDBArchivistBase {
42
105
  queries = [
43
106
  ArchivistInsertQuerySchema,
44
107
  ...super.queries
@@ -47,7 +110,7 @@ class MongoDBArchivist extends MongoDBArchivistBase {
47
110
  const head = await (await this.payloads.find({})).sort({
48
111
  _timestamp: -1
49
112
  }).limit(1).toArray();
50
- return head[0] ? PayloadWrapper.wrap(head[0]).body() : void 0;
113
+ return head[0] ? PayloadWrapper3.wrap(head[0]).body() : void 0;
51
114
  }
52
115
  async getHandler(hashes) {
53
116
  const payloads = hashes.map((_hash) => this.payloads.findOne({
@@ -93,7 +156,13 @@ class MongoDBArchivist extends MongoDBArchivistBase {
93
156
  });
94
157
  return true;
95
158
  }
96
- }
159
+ };
160
+ __name(_MongoDBArchivist, "MongoDBArchivist");
161
+ __publicField(_MongoDBArchivist, "configSchemas", [
162
+ MongoDBArchivistConfigSchema,
163
+ ArchivistConfigSchema
164
+ ]);
165
+ var MongoDBArchivist = _MongoDBArchivist;
97
166
  export {
98
167
  MongoDBArchivist
99
168
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Archivist.ts"],"sourcesContent":["import { exists } from '@xylabs/exists'\nimport { fulfilledValues } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport { ArchivistConfigSchema, ArchivistInsertQuerySchema } from '@xyo-network/archivist-model'\nimport { MongoDBArchivistConfigSchema } from '@xyo-network/archivist-model-mongodb'\nimport { CollectionIndexFunction, MongoDBModuleMixin } from '@xyo-network/module-abstract-mongodb'\nimport { PayloadWithPartialMeta } from '@xyo-network/node-core-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\nimport { IndexDescription } from 'mongodb'\n\nimport { toBoundWitnessWithMeta, toPayloadWithMeta, toReturnValue, validByType } from './lib'\n\nconst getBoundWitnessesIndexes: CollectionIndexFunction = (collectionName: string): IndexDescription[] => {\n return [\n {\n // eslint-disable-next-line sort-keys-fix/sort-keys-fix\n key: { _hash: 1 },\n name: `${collectionName}.IX__hash`,\n },\n ]\n}\n\nconst getPayloadsIndexes: CollectionIndexFunction = (collectionName: string): IndexDescription[] => {\n return [\n {\n // eslint-disable-next-line sort-keys-fix/sort-keys-fix\n key: { _hash: 1 },\n name: `${collectionName}.IX__hash`,\n },\n ]\n}\n\nconst MongoDBArchivistBase = MongoDBModuleMixin(AbstractArchivist)\n\nexport class MongoDBArchivist extends MongoDBArchivistBase {\n static override configSchemas = [MongoDBArchivistConfigSchema, ArchivistConfigSchema]\n\n override readonly queries: string[] = [ArchivistInsertQuerySchema, ...super.queries]\n\n override async head(): Promise<Payload | undefined> {\n const head = await (await this.payloads.find({})).sort({ _timestamp: -1 }).limit(1).toArray()\n return head[0] ? PayloadWrapper.wrap(head[0]).body() : undefined\n }\n\n protected override async getHandler(hashes: string[]): Promise<Payload[]> {\n const payloads = hashes.map((_hash) => this.payloads.findOne({ _hash }))\n const bws = hashes.map((_hash) => this.boundWitnesses.findOne({ _hash }))\n const gets = await Promise.allSettled([payloads, bws].flat())\n const succeeded = gets.reduce<(PayloadWithPartialMeta | null)[]>(fulfilledValues, []) as Payload[]\n return succeeded.filter(exists).map(toReturnValue)\n }\n\n protected override async insertHandler(payloads?: Payload[]): Promise<Payload[]> {\n const [bw, p] = await validByType(payloads)\n const boundWitnesses = await Promise.all(bw.map((x) => toBoundWitnessWithMeta(x)))\n const payloadsWithMeta = await Promise.all(p.map((x) => toPayloadWithMeta(x)))\n if (boundWitnesses.length) {\n const boundWitnessesResult = await this.boundWitnesses.insertMany(boundWitnesses)\n if (!boundWitnessesResult.acknowledged || boundWitnessesResult.insertedCount !== boundWitnesses.length)\n throw new Error('MongoDBDeterministicArchivist: Error inserting BoundWitnesses')\n }\n if (payloadsWithMeta.length) {\n const payloadsResult = await this.payloads.insertMany(payloadsWithMeta)\n if (!payloadsResult.acknowledged || payloadsResult.insertedCount !== payloadsWithMeta.length)\n throw new Error('MongoDBDeterministicArchivist: Error inserting Payloads')\n }\n return payloads ?? []\n }\n\n protected override async startHandler() {\n await super.startHandler()\n await this.boundWitnesses.useCollection(async (collection) => {\n const { collectionName } = collection\n const indexes = getBoundWitnessesIndexes(collectionName)\n await collection.createIndexes(indexes)\n })\n await this.payloads.useCollection(async (collection) => {\n const { collectionName } = collection\n const indexes = getPayloadsIndexes(collectionName)\n await collection.createIndexes(indexes)\n })\n return true\n }\n}\n"],"mappings":";;AAAA,SAASA,cAAc;AACvB,SAASC,uBAAuB;AAChC,SAASC,yBAAyB;AAClC,SAASC,uBAAuBC,kCAAkC;AAClE,SAASC,oCAAoC;AAC7C,SAAkCC,0BAA0B;AAG5D,SAASC,sBAAsB;AAG/B,SAASC,wBAAwBC,mBAAmBC,eAAeC,mBAAmB;AAEtF,MAAMC,2BAAoD,wBAACC,mBAAAA;AACzD,SAAO;IACL;;MAEEC,KAAK;QAAEC,OAAO;MAAE;MAChBC,MAAM,GAAGH,cAAAA;IACX;;AAEJ,GAR0D;AAU1D,MAAMI,qBAA8C,wBAACJ,mBAAAA;AACnD,SAAO;IACL;;MAEEC,KAAK;QAAEC,OAAO;MAAE;MAChBC,MAAM,GAAGH,cAAAA;IACX;;AAEJ,GARoD;AAUpD,MAAMK,uBAAuBZ,mBAAmBJ,iBAAAA;AAEzC,MAAMiB,yBAAyBD,qBAAAA;EAnCtC,OAmCsCA;;;EACpC,OAAgBE,gBAAgB;IAACf;IAA8BF;;EAE7CkB,UAAoB;IAACjB;OAA+B,MAAMiB;;EAE5E,MAAeC,OAAqC;AAClD,UAAMA,OAAO,OAAO,MAAM,KAAKC,SAASC,KAAK,CAAC,CAAA,GAAIC,KAAK;MAAEC,YAAY;IAAG,CAAA,EAAGC,MAAM,CAAA,EAAGC,QAAO;AAC3F,WAAON,KAAK,CAAA,IAAKf,eAAesB,KAAKP,KAAK,CAAA,CAAE,EAAEQ,KAAI,IAAKC;EACzD;EAEA,MAAyBC,WAAWC,QAAsC;AACxE,UAAMV,WAAWU,OAAOC,IAAI,CAACnB,UAAU,KAAKQ,SAASY,QAAQ;MAAEpB;IAAM,CAAA,CAAA;AACrE,UAAMqB,MAAMH,OAAOC,IAAI,CAACnB,UAAU,KAAKsB,eAAeF,QAAQ;MAAEpB;IAAM,CAAA,CAAA;AACtE,UAAMuB,OAAO,MAAMC,QAAQC,WAAW;MAACjB;MAAUa;MAAKK,KAAI,CAAA;AAC1D,UAAMC,YAAYJ,KAAKK,OAA0C1C,iBAAiB,CAAA,CAAE;AACpF,WAAOyC,UAAUE,OAAO5C,MAAAA,EAAQkC,IAAIxB,aAAAA;EACtC;EAEA,MAAyBmC,cAActB,UAA0C;AAC/E,UAAM,CAACuB,IAAIC,CAAAA,IAAK,MAAMpC,YAAYY,QAAAA;AAClC,UAAMc,iBAAiB,MAAME,QAAQS,IAAIF,GAAGZ,IAAI,CAACe,MAAMzC,uBAAuByC,CAAAA,CAAAA,CAAAA;AAC9E,UAAMC,mBAAmB,MAAMX,QAAQS,IAAID,EAAEb,IAAI,CAACe,MAAMxC,kBAAkBwC,CAAAA,CAAAA,CAAAA;AAC1E,QAAIZ,eAAec,QAAQ;AACzB,YAAMC,uBAAuB,MAAM,KAAKf,eAAegB,WAAWhB,cAAAA;AAClE,UAAI,CAACe,qBAAqBE,gBAAgBF,qBAAqBG,kBAAkBlB,eAAec;AAC9F,cAAM,IAAIK,MAAM,+DAAA;IACpB;AACA,QAAIN,iBAAiBC,QAAQ;AAC3B,YAAMM,iBAAiB,MAAM,KAAKlC,SAAS8B,WAAWH,gBAAAA;AACtD,UAAI,CAACO,eAAeH,gBAAgBG,eAAeF,kBAAkBL,iBAAiBC;AACpF,cAAM,IAAIK,MAAM,yDAAA;IACpB;AACA,WAAOjC,YAAY,CAAA;EACrB;EAEA,MAAyBmC,eAAe;AACtC,UAAM,MAAMA,aAAAA;AACZ,UAAM,KAAKrB,eAAesB,cAAc,OAAOC,eAAAA;AAC7C,YAAM,EAAE/C,eAAc,IAAK+C;AAC3B,YAAMC,UAAUjD,yBAAyBC,cAAAA;AACzC,YAAM+C,WAAWE,cAAcD,OAAAA;IACjC,CAAA;AACA,UAAM,KAAKtC,SAASoC,cAAc,OAAOC,eAAAA;AACvC,YAAM,EAAE/C,eAAc,IAAK+C;AAC3B,YAAMC,UAAU5C,mBAAmBJ,cAAAA;AACnC,YAAM+C,WAAWE,cAAcD,OAAAA;IACjC,CAAA;AACA,WAAO;EACT;AACF;","names":["exists","fulfilledValues","AbstractArchivist","ArchivistConfigSchema","ArchivistInsertQuerySchema","MongoDBArchivistConfigSchema","MongoDBModuleMixin","PayloadWrapper","toBoundWitnessWithMeta","toPayloadWithMeta","toReturnValue","validByType","getBoundWitnessesIndexes","collectionName","key","_hash","name","getPayloadsIndexes","MongoDBArchivistBase","MongoDBArchivist","configSchemas","queries","head","payloads","find","sort","_timestamp","limit","toArray","wrap","body","undefined","getHandler","hashes","map","findOne","bws","boundWitnesses","gets","Promise","allSettled","flat","succeeded","reduce","filter","insertHandler","bw","p","all","x","payloadsWithMeta","length","boundWitnessesResult","insertMany","acknowledged","insertedCount","Error","payloadsResult","startHandler","useCollection","collection","indexes","createIndexes"]}
1
+ {"version":3,"sources":["../../src/Archivist.ts","../../src/lib/toBoundWitnessWithMeta.ts","../../src/lib/toPayloadWithMeta.ts","../../src/lib/toReturnValue.ts","../../src/lib/validByType.ts"],"sourcesContent":["import { exists } from '@xylabs/exists'\nimport { fulfilledValues } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport { ArchivistConfigSchema, ArchivistInsertQuerySchema } from '@xyo-network/archivist-model'\nimport { MongoDBArchivistConfigSchema } from '@xyo-network/archivist-model-mongodb'\nimport { CollectionIndexFunction, MongoDBModuleMixin } from '@xyo-network/module-abstract-mongodb'\nimport { PayloadWithPartialMeta } from '@xyo-network/node-core-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\nimport { IndexDescription } from 'mongodb'\n\nimport { toBoundWitnessWithMeta, toPayloadWithMeta, toReturnValue, validByType } from './lib'\n\nconst getBoundWitnessesIndexes: CollectionIndexFunction = (collectionName: string): IndexDescription[] => {\n return [\n {\n // eslint-disable-next-line sort-keys-fix/sort-keys-fix\n key: { _hash: 1 },\n name: `${collectionName}.IX__hash`,\n },\n ]\n}\n\nconst getPayloadsIndexes: CollectionIndexFunction = (collectionName: string): IndexDescription[] => {\n return [\n {\n // eslint-disable-next-line sort-keys-fix/sort-keys-fix\n key: { _hash: 1 },\n name: `${collectionName}.IX__hash`,\n },\n ]\n}\n\nconst MongoDBArchivistBase = MongoDBModuleMixin(AbstractArchivist)\n\nexport class MongoDBArchivist extends MongoDBArchivistBase {\n static override configSchemas = [MongoDBArchivistConfigSchema, ArchivistConfigSchema]\n\n override readonly queries: string[] = [ArchivistInsertQuerySchema, ...super.queries]\n\n override async head(): Promise<Payload | undefined> {\n const head = await (await this.payloads.find({})).sort({ _timestamp: -1 }).limit(1).toArray()\n return head[0] ? PayloadWrapper.wrap(head[0]).body() : undefined\n }\n\n protected override async getHandler(hashes: string[]): Promise<Payload[]> {\n const payloads = hashes.map((_hash) => this.payloads.findOne({ _hash }))\n const bws = hashes.map((_hash) => this.boundWitnesses.findOne({ _hash }))\n const gets = await Promise.allSettled([payloads, bws].flat())\n const succeeded = gets.reduce<(PayloadWithPartialMeta | null)[]>(fulfilledValues, []) as Payload[]\n return succeeded.filter(exists).map(toReturnValue)\n }\n\n protected override async insertHandler(payloads?: Payload[]): Promise<Payload[]> {\n const [bw, p] = await validByType(payloads)\n const boundWitnesses = await Promise.all(bw.map((x) => toBoundWitnessWithMeta(x)))\n const payloadsWithMeta = await Promise.all(p.map((x) => toPayloadWithMeta(x)))\n if (boundWitnesses.length) {\n const boundWitnessesResult = await this.boundWitnesses.insertMany(boundWitnesses)\n if (!boundWitnessesResult.acknowledged || boundWitnessesResult.insertedCount !== boundWitnesses.length)\n throw new Error('MongoDBDeterministicArchivist: Error inserting BoundWitnesses')\n }\n if (payloadsWithMeta.length) {\n const payloadsResult = await this.payloads.insertMany(payloadsWithMeta)\n if (!payloadsResult.acknowledged || payloadsResult.insertedCount !== payloadsWithMeta.length)\n throw new Error('MongoDBDeterministicArchivist: Error inserting Payloads')\n }\n return payloads ?? []\n }\n\n protected override async startHandler() {\n await super.startHandler()\n await this.boundWitnesses.useCollection(async (collection) => {\n const { collectionName } = collection\n const indexes = getBoundWitnessesIndexes(collectionName)\n await collection.createIndexes(indexes)\n })\n await this.payloads.useCollection(async (collection) => {\n const { collectionName } = collection\n const indexes = getPayloadsIndexes(collectionName)\n await collection.createIndexes(indexes)\n })\n return true\n }\n}\n","import { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { BoundWitnessWithMeta } from '@xyo-network/node-core-model'\n\nexport const toBoundWitnessWithMeta = async (wrapper: BoundWitnessWrapper | QueryBoundWitnessWrapper): Promise<BoundWitnessWithMeta> => {\n const bw = wrapper.boundwitness as BoundWitness\n return { ...bw, _hash: await wrapper.hashAsync(), _timestamp: Date.now() }\n}\n","import { PayloadWithMeta } from '@xyo-network/node-core-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nexport const toPayloadWithMeta = async (wrapper: PayloadWrapper): Promise<PayloadWithMeta> => {\n return { ...wrapper.payload(), _hash: await wrapper.hashAsync(), _timestamp: Date.now() }\n}\n","import { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nexport const toReturnValue = (value: Payload | BoundWitness): Payload => {\n const _signatures = (value as BoundWitness)?._signatures\n if (_signatures) {\n return { ...PayloadWrapper.wrap(value).body(), _signatures } as BoundWitness\n } else {\n return { ...PayloadWrapper.wrap(value).body() }\n }\n}\n","import { isQueryBoundWitness, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nexport const validByType = async (payloads: Payload[] = []) => {\n const results: [BoundWitnessWrapper[], PayloadWrapper[]] = [[], []]\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(bw)\n }\n } else {\n const payloadWrapper = PayloadWrapper.wrap(payload)\n if (await payloadWrapper.getValid()) {\n results[1].push(payloadWrapper)\n }\n }\n }),\n )\n return results\n}\n"],"mappings":"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","names":["exists","fulfilledValues","AbstractArchivist","ArchivistConfigSchema","ArchivistInsertQuerySchema","MongoDBArchivistConfigSchema","MongoDBModuleMixin","PayloadWrapper","toBoundWitnessWithMeta","wrapper","bw","boundwitness","_hash","hashAsync","_timestamp","Date","now","toPayloadWithMeta","wrapper","payload","_hash","hashAsync","_timestamp","Date","now","PayloadWrapper","toReturnValue","value","_signatures","PayloadWrapper","wrap","body","isQueryBoundWitness","QueryBoundWitnessWrapper","isBoundWitness","BoundWitnessWrapper","PayloadWrapper","validByType","payloads","results","Promise","all","map","payload","isBoundWitness","wrapper","isQueryBoundWitness","QueryBoundWitnessWrapper","BoundWitnessWrapper","bw","parse","getValid","push","payloadWrapper","PayloadWrapper","wrap","getBoundWitnessesIndexes","collectionName","key","_hash","name","getPayloadsIndexes","MongoDBArchivistBase","MongoDBModuleMixin","AbstractArchivist","MongoDBArchivist","queries","ArchivistInsertQuerySchema","head","payloads","find","sort","_timestamp","limit","toArray","PayloadWrapper","wrap","body","undefined","getHandler","hashes","map","findOne","bws","boundWitnesses","gets","Promise","allSettled","flat","succeeded","reduce","fulfilledValues","filter","exists","toReturnValue","insertHandler","bw","p","validByType","all","x","toBoundWitnessWithMeta","payloadsWithMeta","toPayloadWithMeta","length","boundWitnessesResult","insertMany","acknowledged","insertedCount","Error","payloadsResult","startHandler","useCollection","collection","indexes","createIndexes","configSchemas","MongoDBArchivistConfigSchema","ArchivistConfigSchema"]}
@@ -0,0 +1,3 @@
1
+ export * from './Archivist';
2
+ export * from '@xyo-network/archivist-model-mongodb';
3
+ //# sourceMappingURL=index.d.ts.map