@xyo-network/archivist-mongodb 2.74.4 → 2.75.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.
- package/dist/browser/Archivist.cjs +184 -0
- package/dist/browser/Archivist.cjs.map +1 -0
- package/dist/browser/Archivist.d.mts +239 -0
- package/dist/browser/Archivist.d.mts.map +1 -0
- package/dist/browser/Archivist.d.ts +239 -0
- package/dist/browser/Archivist.d.ts.map +1 -0
- package/dist/browser/Archivist.js +165 -0
- package/dist/browser/Archivist.js.map +1 -0
- package/dist/{index.js → browser/index.cjs} +83 -85
- package/dist/browser/index.cjs.map +1 -0
- package/dist/browser/index.d.mts.map +1 -0
- package/dist/browser/index.d.ts.map +1 -0
- package/dist/{index.mjs → browser/index.js} +83 -80
- package/dist/browser/index.js.map +1 -0
- package/dist/browser/lib/index.cjs +92 -0
- package/dist/browser/lib/index.cjs.map +1 -0
- package/dist/browser/lib/index.d.mts +5 -0
- package/dist/browser/lib/index.d.mts.map +1 -0
- package/dist/browser/lib/index.d.ts +5 -0
- package/dist/browser/lib/index.d.ts.map +1 -0
- package/dist/browser/lib/index.js +71 -0
- package/dist/browser/lib/index.js.map +1 -0
- package/dist/browser/lib/toBoundWitnessWithMeta.cjs +35 -0
- package/dist/browser/lib/toBoundWitnessWithMeta.cjs.map +1 -0
- package/dist/browser/lib/toBoundWitnessWithMeta.d.mts +5 -0
- package/dist/browser/lib/toBoundWitnessWithMeta.d.mts.map +1 -0
- package/dist/browser/lib/toBoundWitnessWithMeta.d.ts +5 -0
- package/dist/browser/lib/toBoundWitnessWithMeta.d.ts.map +1 -0
- package/dist/browser/lib/toBoundWitnessWithMeta.js +16 -0
- package/dist/browser/lib/toBoundWitnessWithMeta.js.map +1 -0
- package/dist/browser/lib/toPayloadWithMeta.cjs +34 -0
- package/dist/browser/lib/toPayloadWithMeta.cjs.map +1 -0
- package/dist/browser/lib/toPayloadWithMeta.d.mts +4 -0
- package/dist/browser/lib/toPayloadWithMeta.d.mts.map +1 -0
- package/dist/browser/lib/toPayloadWithMeta.d.ts +4 -0
- package/dist/browser/lib/toPayloadWithMeta.d.ts.map +1 -0
- package/dist/browser/lib/toPayloadWithMeta.js +15 -0
- package/dist/browser/lib/toPayloadWithMeta.js.map +1 -0
- package/dist/browser/lib/toReturnValue.cjs +41 -0
- package/dist/browser/lib/toReturnValue.cjs.map +1 -0
- package/dist/browser/lib/toReturnValue.d.mts +4 -0
- package/dist/browser/lib/toReturnValue.d.mts.map +1 -0
- package/dist/browser/lib/toReturnValue.d.ts +4 -0
- package/dist/browser/lib/toReturnValue.d.ts.map +1 -0
- package/dist/browser/lib/toReturnValue.js +22 -0
- package/dist/browser/lib/toReturnValue.js.map +1 -0
- package/dist/browser/lib/validByType.cjs +52 -0
- package/dist/browser/lib/validByType.cjs.map +1 -0
- package/dist/browser/lib/validByType.d.mts.map +1 -0
- package/dist/browser/lib/validByType.d.ts.map +1 -0
- package/dist/browser/lib/validByType.js +33 -0
- package/dist/browser/lib/validByType.js.map +1 -0
- package/dist/node/Archivist.d.mts +239 -0
- package/dist/node/Archivist.d.mts.map +1 -0
- package/dist/node/Archivist.d.ts +239 -0
- package/dist/node/Archivist.d.ts.map +1 -0
- package/dist/node/Archivist.js +123 -0
- package/dist/node/Archivist.js.map +1 -0
- package/dist/node/Archivist.mjs +100 -0
- package/dist/node/Archivist.mjs.map +1 -0
- package/dist/node/index.d.mts +3 -0
- package/dist/node/index.d.mts.map +1 -0
- package/dist/node/index.d.ts +3 -0
- package/dist/node/index.d.ts.map +1 -0
- package/dist/node/index.js +25 -0
- package/dist/node/index.js.map +1 -0
- package/dist/node/index.mjs +3 -0
- package/dist/node/index.mjs.map +1 -0
- package/dist/node/lib/index.d.mts +5 -0
- package/dist/node/lib/index.d.mts.map +1 -0
- package/dist/node/lib/index.d.ts +5 -0
- package/dist/node/lib/index.d.ts.map +1 -0
- package/dist/node/lib/index.js +29 -0
- package/dist/node/lib/index.js.map +1 -0
- package/dist/node/lib/index.mjs +5 -0
- package/dist/node/lib/index.mjs.map +1 -0
- package/dist/node/lib/toBoundWitnessWithMeta.d.mts +5 -0
- package/dist/node/lib/toBoundWitnessWithMeta.d.mts.map +1 -0
- package/dist/node/lib/toBoundWitnessWithMeta.d.ts +5 -0
- package/dist/node/lib/toBoundWitnessWithMeta.d.ts.map +1 -0
- package/dist/node/lib/toBoundWitnessWithMeta.js +37 -0
- package/dist/node/lib/toBoundWitnessWithMeta.js.map +1 -0
- package/dist/node/lib/toBoundWitnessWithMeta.mjs +14 -0
- package/dist/node/lib/toBoundWitnessWithMeta.mjs.map +1 -0
- package/dist/node/lib/toPayloadWithMeta.d.mts +4 -0
- package/dist/node/lib/toPayloadWithMeta.d.mts.map +1 -0
- package/dist/node/lib/toPayloadWithMeta.d.ts +4 -0
- package/dist/node/lib/toPayloadWithMeta.d.ts.map +1 -0
- package/dist/node/lib/toPayloadWithMeta.js +36 -0
- package/dist/node/lib/toPayloadWithMeta.js.map +1 -0
- package/dist/node/lib/toPayloadWithMeta.mjs +13 -0
- package/dist/node/lib/toPayloadWithMeta.mjs.map +1 -0
- package/dist/node/lib/toReturnValue.d.mts +4 -0
- package/dist/node/lib/toReturnValue.d.mts.map +1 -0
- package/dist/node/lib/toReturnValue.d.ts +4 -0
- package/dist/node/lib/toReturnValue.d.ts.map +1 -0
- package/dist/node/lib/toReturnValue.js +43 -0
- package/dist/node/lib/toReturnValue.js.map +1 -0
- package/dist/node/lib/toReturnValue.mjs +20 -0
- package/dist/node/lib/toReturnValue.mjs.map +1 -0
- package/dist/node/lib/validByType.d.mts +11 -0
- package/dist/node/lib/validByType.d.mts.map +1 -0
- package/dist/node/lib/validByType.d.ts +11 -0
- package/dist/node/lib/validByType.d.ts.map +1 -0
- package/dist/node/lib/validByType.js +54 -0
- package/dist/node/lib/validByType.js.map +1 -0
- package/dist/node/lib/validByType.mjs +31 -0
- package/dist/node/lib/validByType.mjs.map +1 -0
- package/package.json +39 -33
- package/src/Archivist.ts +39 -56
- package/src/lib/index.ts +3 -0
- package/src/lib/toBoundWitnessWithMeta.ts +9 -0
- package/src/lib/toPayloadWithMeta.ts +6 -0
- package/src/lib/toReturnValue.ts +12 -0
- package/dist/Archivist.d.mts +0 -23
- package/dist/Archivist.d.mts.map +0 -1
- package/dist/Archivist.d.ts +0 -23
- package/dist/Archivist.d.ts.map +0 -1
- package/dist/docs.json +0 -23531
- package/dist/index.d.mts.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/index.mjs.map +0 -1
- package/dist/lib/index.d.mts +0 -2
- package/dist/lib/index.d.mts.map +0 -1
- package/dist/lib/index.d.ts +0 -2
- package/dist/lib/index.d.ts.map +0 -1
- package/dist/lib/validByType.d.mts.map +0 -1
- package/dist/lib/validByType.d.ts.map +0 -1
- /package/dist/{index.d.mts → browser/index.d.mts} +0 -0
- /package/dist/{index.d.ts → browser/index.d.ts} +0 -0
- /package/dist/{lib → browser/lib}/validByType.d.mts +0 -0
- /package/dist/{lib → browser/lib}/validByType.d.ts +0 -0
|
@@ -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"}
|
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
|
+
|
|
4
|
+
// src/Archivist.ts
|
|
5
|
+
import { exists } from "@xylabs/exists";
|
|
6
|
+
import { fulfilledValues } from "@xylabs/promise";
|
|
7
|
+
import { AbstractArchivist } from "@xyo-network/archivist-abstract";
|
|
8
|
+
import { ArchivistConfigSchema, ArchivistInsertQuerySchema } from "@xyo-network/archivist-model";
|
|
9
|
+
import { MongoDBArchivistConfigSchema } from "@xyo-network/archivist-model-mongodb";
|
|
10
|
+
import { MongoDBModuleMixin } from "@xyo-network/module-abstract-mongodb";
|
|
11
|
+
import { PayloadWrapper as PayloadWrapper3 } from "@xyo-network/payload-wrapper";
|
|
12
|
+
|
|
13
|
+
// src/lib/toBoundWitnessWithMeta.ts
|
|
14
|
+
var toBoundWitnessWithMeta = /* @__PURE__ */ __name(async (wrapper) => {
|
|
15
|
+
const bw = wrapper.boundwitness;
|
|
16
|
+
return {
|
|
17
|
+
...bw,
|
|
18
|
+
_hash: await wrapper.hashAsync(),
|
|
19
|
+
_timestamp: Date.now()
|
|
20
|
+
};
|
|
21
|
+
}, "toBoundWitnessWithMeta");
|
|
22
|
+
|
|
23
|
+
// src/lib/toPayloadWithMeta.ts
|
|
24
|
+
var toPayloadWithMeta = /* @__PURE__ */ __name(async (wrapper) => {
|
|
25
|
+
return {
|
|
26
|
+
...wrapper.payload(),
|
|
27
|
+
_hash: await wrapper.hashAsync(),
|
|
28
|
+
_timestamp: Date.now()
|
|
29
|
+
};
|
|
30
|
+
}, "toPayloadWithMeta");
|
|
31
|
+
|
|
32
|
+
// src/lib/toReturnValue.ts
|
|
33
|
+
import { PayloadWrapper } from "@xyo-network/payload-wrapper";
|
|
34
|
+
var toReturnValue = /* @__PURE__ */ __name((value) => {
|
|
35
|
+
const _signatures = value?._signatures;
|
|
36
|
+
if (_signatures) {
|
|
37
|
+
return {
|
|
38
|
+
...PayloadWrapper.wrap(value).body(),
|
|
39
|
+
_signatures
|
|
40
|
+
};
|
|
41
|
+
} else {
|
|
42
|
+
return {
|
|
43
|
+
...PayloadWrapper.wrap(value).body()
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
}, "toReturnValue");
|
|
47
|
+
|
|
48
|
+
// src/lib/validByType.ts
|
|
49
|
+
import { isQueryBoundWitness, QueryBoundWitnessWrapper } from "@xyo-network/boundwitness-builder";
|
|
50
|
+
import { isBoundWitness } from "@xyo-network/boundwitness-model";
|
|
51
|
+
import { BoundWitnessWrapper } from "@xyo-network/boundwitness-wrapper";
|
|
52
|
+
import { PayloadWrapper as PayloadWrapper2 } from "@xyo-network/payload-wrapper";
|
|
53
|
+
var validByType = /* @__PURE__ */ __name(async (payloads = []) => {
|
|
54
|
+
const results = [
|
|
55
|
+
[],
|
|
56
|
+
[]
|
|
57
|
+
];
|
|
58
|
+
await Promise.all(payloads.map(async (payload) => {
|
|
59
|
+
if (isBoundWitness(payload)) {
|
|
60
|
+
const wrapper = isQueryBoundWitness(payload) ? QueryBoundWitnessWrapper : BoundWitnessWrapper;
|
|
61
|
+
const bw = wrapper.parse(payload);
|
|
62
|
+
if (await bw.getValid()) {
|
|
63
|
+
results[0].push(bw);
|
|
64
|
+
}
|
|
65
|
+
} else {
|
|
66
|
+
const payloadWrapper = PayloadWrapper2.wrap(payload);
|
|
67
|
+
if (await payloadWrapper.getValid()) {
|
|
68
|
+
results[1].push(payloadWrapper);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}));
|
|
72
|
+
return results;
|
|
73
|
+
}, "validByType");
|
|
74
|
+
|
|
75
|
+
// src/Archivist.ts
|
|
76
|
+
var getBoundWitnessesIndexes = /* @__PURE__ */ __name((collectionName) => {
|
|
77
|
+
return [
|
|
78
|
+
{
|
|
79
|
+
// eslint-disable-next-line sort-keys-fix/sort-keys-fix
|
|
80
|
+
key: {
|
|
81
|
+
_hash: 1
|
|
82
|
+
},
|
|
83
|
+
name: `${collectionName}.IX__hash`
|
|
84
|
+
}
|
|
85
|
+
];
|
|
86
|
+
}, "getBoundWitnessesIndexes");
|
|
87
|
+
var getPayloadsIndexes = /* @__PURE__ */ __name((collectionName) => {
|
|
88
|
+
return [
|
|
89
|
+
{
|
|
90
|
+
// eslint-disable-next-line sort-keys-fix/sort-keys-fix
|
|
91
|
+
key: {
|
|
92
|
+
_hash: 1
|
|
93
|
+
},
|
|
94
|
+
name: `${collectionName}.IX__hash`
|
|
95
|
+
}
|
|
96
|
+
];
|
|
97
|
+
}, "getPayloadsIndexes");
|
|
98
|
+
var MongoDBArchivistBase = MongoDBModuleMixin(AbstractArchivist);
|
|
99
|
+
var MongoDBArchivist = class extends MongoDBArchivistBase {
|
|
100
|
+
static {
|
|
101
|
+
__name(this, "MongoDBArchivist");
|
|
102
|
+
}
|
|
103
|
+
static configSchemas = [
|
|
104
|
+
MongoDBArchivistConfigSchema,
|
|
105
|
+
ArchivistConfigSchema
|
|
106
|
+
];
|
|
107
|
+
queries = [
|
|
108
|
+
ArchivistInsertQuerySchema,
|
|
109
|
+
...super.queries
|
|
110
|
+
];
|
|
111
|
+
async head() {
|
|
112
|
+
const head = await (await this.payloads.find({})).sort({
|
|
113
|
+
_timestamp: -1
|
|
114
|
+
}).limit(1).toArray();
|
|
115
|
+
return head[0] ? PayloadWrapper3.wrap(head[0]).body() : void 0;
|
|
116
|
+
}
|
|
117
|
+
async getHandler(hashes) {
|
|
118
|
+
const payloads = hashes.map((_hash) => this.payloads.findOne({
|
|
119
|
+
_hash
|
|
120
|
+
}));
|
|
121
|
+
const bws = hashes.map((_hash) => this.boundWitnesses.findOne({
|
|
122
|
+
_hash
|
|
123
|
+
}));
|
|
124
|
+
const gets = await Promise.allSettled([
|
|
125
|
+
payloads,
|
|
126
|
+
bws
|
|
127
|
+
].flat());
|
|
128
|
+
const succeeded = gets.reduce(fulfilledValues, []);
|
|
129
|
+
return succeeded.filter(exists).map(toReturnValue);
|
|
130
|
+
}
|
|
131
|
+
async insertHandler(payloads) {
|
|
132
|
+
const [bw, p] = await validByType(payloads);
|
|
133
|
+
const boundWitnesses = await Promise.all(bw.map((x) => toBoundWitnessWithMeta(x)));
|
|
134
|
+
const payloadsWithMeta = await Promise.all(p.map((x) => toPayloadWithMeta(x)));
|
|
135
|
+
if (boundWitnesses.length) {
|
|
136
|
+
const boundWitnessesResult = await this.boundWitnesses.insertMany(boundWitnesses);
|
|
137
|
+
if (!boundWitnessesResult.acknowledged || boundWitnessesResult.insertedCount !== boundWitnesses.length)
|
|
138
|
+
throw new Error("MongoDBDeterministicArchivist: Error inserting BoundWitnesses");
|
|
139
|
+
}
|
|
140
|
+
if (payloadsWithMeta.length) {
|
|
141
|
+
const payloadsResult = await this.payloads.insertMany(payloadsWithMeta);
|
|
142
|
+
if (!payloadsResult.acknowledged || payloadsResult.insertedCount !== payloadsWithMeta.length)
|
|
143
|
+
throw new Error("MongoDBDeterministicArchivist: Error inserting Payloads");
|
|
144
|
+
}
|
|
145
|
+
return payloads ?? [];
|
|
146
|
+
}
|
|
147
|
+
async startHandler() {
|
|
148
|
+
await super.startHandler();
|
|
149
|
+
await this.boundWitnesses.useCollection(async (collection) => {
|
|
150
|
+
const { collectionName } = collection;
|
|
151
|
+
const indexes = getBoundWitnessesIndexes(collectionName);
|
|
152
|
+
await collection.createIndexes(indexes);
|
|
153
|
+
});
|
|
154
|
+
await this.payloads.useCollection(async (collection) => {
|
|
155
|
+
const { collectionName } = collection;
|
|
156
|
+
const indexes = getPayloadsIndexes(collectionName);
|
|
157
|
+
await collection.createIndexes(indexes);
|
|
158
|
+
});
|
|
159
|
+
return true;
|
|
160
|
+
}
|
|
161
|
+
};
|
|
162
|
+
export {
|
|
163
|
+
MongoDBArchivist
|
|
164
|
+
};
|
|
165
|
+
//# sourceMappingURL=Archivist.js.map
|
|
@@ -0,0 +1 @@
|
|
|
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","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"]}
|
|
@@ -27,23 +27,54 @@ __export(src_exports, {
|
|
|
27
27
|
module.exports = __toCommonJS(src_exports);
|
|
28
28
|
|
|
29
29
|
// src/Archivist.ts
|
|
30
|
-
var import_assert = require("@xylabs/assert");
|
|
31
30
|
var import_exists = require("@xylabs/exists");
|
|
32
|
-
var import_lodash = require("@xylabs/lodash");
|
|
33
31
|
var import_promise = require("@xylabs/promise");
|
|
34
|
-
var import_static_implements = require("@xylabs/static-implements");
|
|
35
32
|
var import_archivist_abstract = require("@xyo-network/archivist-abstract");
|
|
36
33
|
var import_archivist_model = require("@xyo-network/archivist-model");
|
|
37
34
|
var import_archivist_model_mongodb = require("@xyo-network/archivist-model-mongodb");
|
|
38
|
-
var
|
|
39
|
-
var
|
|
40
|
-
|
|
35
|
+
var import_module_abstract_mongodb = require("@xyo-network/module-abstract-mongodb");
|
|
36
|
+
var import_payload_wrapper3 = require("@xyo-network/payload-wrapper");
|
|
37
|
+
|
|
38
|
+
// src/lib/toBoundWitnessWithMeta.ts
|
|
39
|
+
var toBoundWitnessWithMeta = /* @__PURE__ */ __name(async (wrapper) => {
|
|
40
|
+
const bw = wrapper.boundwitness;
|
|
41
|
+
return {
|
|
42
|
+
...bw,
|
|
43
|
+
_hash: await wrapper.hashAsync(),
|
|
44
|
+
_timestamp: Date.now()
|
|
45
|
+
};
|
|
46
|
+
}, "toBoundWitnessWithMeta");
|
|
47
|
+
|
|
48
|
+
// src/lib/toPayloadWithMeta.ts
|
|
49
|
+
var toPayloadWithMeta = /* @__PURE__ */ __name(async (wrapper) => {
|
|
50
|
+
return {
|
|
51
|
+
...wrapper.payload(),
|
|
52
|
+
_hash: await wrapper.hashAsync(),
|
|
53
|
+
_timestamp: Date.now()
|
|
54
|
+
};
|
|
55
|
+
}, "toPayloadWithMeta");
|
|
56
|
+
|
|
57
|
+
// src/lib/toReturnValue.ts
|
|
58
|
+
var import_payload_wrapper = require("@xyo-network/payload-wrapper");
|
|
59
|
+
var toReturnValue = /* @__PURE__ */ __name((value) => {
|
|
60
|
+
const _signatures = value?._signatures;
|
|
61
|
+
if (_signatures) {
|
|
62
|
+
return {
|
|
63
|
+
...import_payload_wrapper.PayloadWrapper.wrap(value).body(),
|
|
64
|
+
_signatures
|
|
65
|
+
};
|
|
66
|
+
} else {
|
|
67
|
+
return {
|
|
68
|
+
...import_payload_wrapper.PayloadWrapper.wrap(value).body()
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
}, "toReturnValue");
|
|
41
72
|
|
|
42
73
|
// src/lib/validByType.ts
|
|
43
74
|
var import_boundwitness_builder = require("@xyo-network/boundwitness-builder");
|
|
44
75
|
var import_boundwitness_model = require("@xyo-network/boundwitness-model");
|
|
45
76
|
var import_boundwitness_wrapper = require("@xyo-network/boundwitness-wrapper");
|
|
46
|
-
var
|
|
77
|
+
var import_payload_wrapper2 = require("@xyo-network/payload-wrapper");
|
|
47
78
|
var validByType = /* @__PURE__ */ __name(async (payloads = []) => {
|
|
48
79
|
const results = [
|
|
49
80
|
[],
|
|
@@ -57,7 +88,7 @@ var validByType = /* @__PURE__ */ __name(async (payloads = []) => {
|
|
|
57
88
|
results[0].push(bw);
|
|
58
89
|
}
|
|
59
90
|
} else {
|
|
60
|
-
const payloadWrapper =
|
|
91
|
+
const payloadWrapper = import_payload_wrapper2.PayloadWrapper.wrap(payload);
|
|
61
92
|
if (await payloadWrapper.getValid()) {
|
|
62
93
|
results[1].push(payloadWrapper);
|
|
63
94
|
}
|
|
@@ -67,46 +98,30 @@ var validByType = /* @__PURE__ */ __name(async (payloads = []) => {
|
|
|
67
98
|
}, "validByType");
|
|
68
99
|
|
|
69
100
|
// src/Archivist.ts
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
var
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
_signatures
|
|
95
|
-
};
|
|
96
|
-
} else {
|
|
97
|
-
return {
|
|
98
|
-
...import_payload_wrapper2.PayloadWrapper.wrap(value).body()
|
|
99
|
-
};
|
|
100
|
-
}
|
|
101
|
-
}, "toReturnValue");
|
|
102
|
-
var toPayloadWithMeta = /* @__PURE__ */ __name(async (wrapper) => {
|
|
103
|
-
return {
|
|
104
|
-
...wrapper.payload(),
|
|
105
|
-
_hash: await wrapper.hashAsync(),
|
|
106
|
-
_timestamp: Date.now()
|
|
107
|
-
};
|
|
108
|
-
}, "toPayloadWithMeta");
|
|
109
|
-
var MongoDBArchivist = class MongoDBArchivist2 extends import_archivist_abstract.AbstractArchivist {
|
|
101
|
+
var getBoundWitnessesIndexes = /* @__PURE__ */ __name((collectionName) => {
|
|
102
|
+
return [
|
|
103
|
+
{
|
|
104
|
+
// eslint-disable-next-line sort-keys-fix/sort-keys-fix
|
|
105
|
+
key: {
|
|
106
|
+
_hash: 1
|
|
107
|
+
},
|
|
108
|
+
name: `${collectionName}.IX__hash`
|
|
109
|
+
}
|
|
110
|
+
];
|
|
111
|
+
}, "getBoundWitnessesIndexes");
|
|
112
|
+
var getPayloadsIndexes = /* @__PURE__ */ __name((collectionName) => {
|
|
113
|
+
return [
|
|
114
|
+
{
|
|
115
|
+
// eslint-disable-next-line sort-keys-fix/sort-keys-fix
|
|
116
|
+
key: {
|
|
117
|
+
_hash: 1
|
|
118
|
+
},
|
|
119
|
+
name: `${collectionName}.IX__hash`
|
|
120
|
+
}
|
|
121
|
+
];
|
|
122
|
+
}, "getPayloadsIndexes");
|
|
123
|
+
var MongoDBArchivistBase = (0, import_module_abstract_mongodb.MongoDBModuleMixin)(import_archivist_abstract.AbstractArchivist);
|
|
124
|
+
var MongoDBArchivist = class extends MongoDBArchivistBase {
|
|
110
125
|
static {
|
|
111
126
|
__name(this, "MongoDBArchivist");
|
|
112
127
|
}
|
|
@@ -114,38 +129,15 @@ var MongoDBArchivist = class MongoDBArchivist2 extends import_archivist_abstract
|
|
|
114
129
|
import_archivist_model_mongodb.MongoDBArchivistConfigSchema,
|
|
115
130
|
import_archivist_model.ArchivistConfigSchema
|
|
116
131
|
];
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
return (0, import_lodash.merge)({}, this.params.boundWitnessSdkConfig, this.config.boundWitnessSdkConfig, {
|
|
122
|
-
collection: this.config.boundWitnessSdkConfig?.collection ?? this.params.boundWitnessSdkConfig?.collection ?? "bound_witnesses"
|
|
123
|
-
});
|
|
124
|
-
}
|
|
125
|
-
get boundWitnesses() {
|
|
126
|
-
this._boundWitnessSdk = this._boundWitnessSdk ?? new import_sdk_xyo_mongo_js.BaseMongoSdk(this.boundWitnessSdkConfig);
|
|
127
|
-
return (0, import_assert.assertEx)(this._boundWitnessSdk);
|
|
128
|
-
}
|
|
129
|
-
get payloadSdkConfig() {
|
|
130
|
-
return (0, import_lodash.merge)({}, this.params.payloadSdkConfig, this.config.payloadSdkConfig, {
|
|
131
|
-
collection: this.config.payloadSdkConfig?.collection ?? this.params.payloadSdkConfig?.collection ?? "payload"
|
|
132
|
-
});
|
|
133
|
-
}
|
|
134
|
-
get payloads() {
|
|
135
|
-
this._payloadSdk = this._payloadSdk ?? new import_sdk_xyo_mongo_js.BaseMongoSdk(this.payloadSdkConfig);
|
|
136
|
-
return (0, import_assert.assertEx)(this._payloadSdk);
|
|
137
|
-
}
|
|
138
|
-
get queries() {
|
|
139
|
-
return [
|
|
140
|
-
import_archivist_model.ArchivistInsertQuerySchema,
|
|
141
|
-
...super.queries
|
|
142
|
-
];
|
|
143
|
-
}
|
|
132
|
+
queries = [
|
|
133
|
+
import_archivist_model.ArchivistInsertQuerySchema,
|
|
134
|
+
...super.queries
|
|
135
|
+
];
|
|
144
136
|
async head() {
|
|
145
137
|
const head = await (await this.payloads.find({})).sort({
|
|
146
138
|
_timestamp: -1
|
|
147
139
|
}).limit(1).toArray();
|
|
148
|
-
return head[0] ?
|
|
140
|
+
return head[0] ? import_payload_wrapper3.PayloadWrapper.wrap(head[0]).body() : void 0;
|
|
149
141
|
}
|
|
150
142
|
async getHandler(hashes) {
|
|
151
143
|
const payloads = hashes.map((_hash) => this.payloads.findOne({
|
|
@@ -177,16 +169,22 @@ var MongoDBArchivist = class MongoDBArchivist2 extends import_archivist_abstract
|
|
|
177
169
|
}
|
|
178
170
|
return payloads ?? [];
|
|
179
171
|
}
|
|
172
|
+
async startHandler() {
|
|
173
|
+
await super.startHandler();
|
|
174
|
+
await this.boundWitnesses.useCollection(async (collection) => {
|
|
175
|
+
const { collectionName } = collection;
|
|
176
|
+
const indexes = getBoundWitnessesIndexes(collectionName);
|
|
177
|
+
await collection.createIndexes(indexes);
|
|
178
|
+
});
|
|
179
|
+
await this.payloads.useCollection(async (collection) => {
|
|
180
|
+
const { collectionName } = collection;
|
|
181
|
+
const indexes = getPayloadsIndexes(collectionName);
|
|
182
|
+
await collection.createIndexes(indexes);
|
|
183
|
+
});
|
|
184
|
+
return true;
|
|
185
|
+
}
|
|
180
186
|
};
|
|
181
|
-
MongoDBArchivist = _ts_decorate([
|
|
182
|
-
(0, import_static_implements.staticImplements)()
|
|
183
|
-
], MongoDBArchivist);
|
|
184
187
|
|
|
185
188
|
// src/index.ts
|
|
186
189
|
__reExport(src_exports, require("@xyo-network/archivist-model-mongodb"), module.exports);
|
|
187
|
-
|
|
188
|
-
0 && (module.exports = {
|
|
189
|
-
MongoDBArchivist,
|
|
190
|
-
...require("@xyo-network/archivist-model-mongodb")
|
|
191
|
-
});
|
|
192
|
-
//# sourceMappingURL=index.js.map
|
|
190
|
+
//# sourceMappingURL=index.cjs.map
|