@xyo-network/crypto-nft-collection-witness-plugin 2.99.4 → 2.99.5

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 (123) hide show
  1. package/dist/browser/Plugin.d.cts +1 -1
  2. package/dist/browser/Plugin.d.mts +1 -1
  3. package/dist/browser/Plugin.d.ts +1 -1
  4. package/dist/browser/index.cjs +175 -127
  5. package/dist/browser/index.cjs.map +1 -1
  6. package/dist/browser/index.d.cts +3 -3
  7. package/dist/browser/index.d.mts +3 -3
  8. package/dist/browser/index.d.ts +3 -3
  9. package/dist/browser/index.mjs +325 -0
  10. package/dist/browser/index.mjs.map +1 -0
  11. package/dist/browser/lib/collectionMetrics/index.d.cts +1 -1
  12. package/dist/browser/lib/collectionMetrics/index.d.mts +1 -1
  13. package/dist/browser/lib/collectionMetrics/index.d.ts +1 -1
  14. package/dist/browser/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.d.cts +1 -1
  15. package/dist/browser/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.d.mts +1 -1
  16. package/dist/browser/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.d.ts +1 -1
  17. package/dist/browser/lib/collectionMetrics/lib/calculatePropertyDistribution.d.cts +1 -1
  18. package/dist/browser/lib/collectionMetrics/lib/calculatePropertyDistribution.d.mts +1 -1
  19. package/dist/browser/lib/collectionMetrics/lib/calculatePropertyDistribution.d.ts +1 -1
  20. package/dist/browser/lib/collectionMetrics/lib/index.d.cts +3 -3
  21. package/dist/browser/lib/collectionMetrics/lib/index.d.mts +3 -3
  22. package/dist/browser/lib/collectionMetrics/lib/index.d.ts +3 -3
  23. package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.d.cts +2 -2
  24. package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.d.mts +2 -2
  25. package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.d.ts +2 -2
  26. package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/index.d.cts +1 -1
  27. package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/index.d.mts +1 -1
  28. package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/index.d.ts +1 -1
  29. package/dist/browser/lib/index.d.cts +4 -4
  30. package/dist/browser/lib/index.d.mts +4 -4
  31. package/dist/browser/lib/index.d.ts +4 -4
  32. package/dist/browser/lib/nonEvaluableContractAddresses.d.cts.map +1 -1
  33. package/dist/browser/lib/nonEvaluableContractAddresses.d.mts.map +1 -1
  34. package/dist/browser/lib/nonEvaluableContractAddresses.d.ts.map +1 -1
  35. package/dist/neutral/Plugin.d.cts +1 -1
  36. package/dist/neutral/Plugin.d.mts +1 -1
  37. package/dist/neutral/Plugin.d.ts +1 -1
  38. package/dist/neutral/index.cjs +175 -127
  39. package/dist/neutral/index.cjs.map +1 -1
  40. package/dist/neutral/index.d.cts +3 -3
  41. package/dist/neutral/index.d.mts +3 -3
  42. package/dist/neutral/index.d.ts +3 -3
  43. package/dist/neutral/index.mjs +325 -0
  44. package/dist/neutral/index.mjs.map +1 -0
  45. package/dist/neutral/lib/collectionMetrics/index.d.cts +1 -1
  46. package/dist/neutral/lib/collectionMetrics/index.d.mts +1 -1
  47. package/dist/neutral/lib/collectionMetrics/index.d.ts +1 -1
  48. package/dist/neutral/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.d.cts +1 -1
  49. package/dist/neutral/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.d.mts +1 -1
  50. package/dist/neutral/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.d.ts +1 -1
  51. package/dist/neutral/lib/collectionMetrics/lib/calculatePropertyDistribution.d.cts +1 -1
  52. package/dist/neutral/lib/collectionMetrics/lib/calculatePropertyDistribution.d.mts +1 -1
  53. package/dist/neutral/lib/collectionMetrics/lib/calculatePropertyDistribution.d.ts +1 -1
  54. package/dist/neutral/lib/collectionMetrics/lib/index.d.cts +3 -3
  55. package/dist/neutral/lib/collectionMetrics/lib/index.d.mts +3 -3
  56. package/dist/neutral/lib/collectionMetrics/lib/index.d.ts +3 -3
  57. package/dist/neutral/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.d.cts +2 -2
  58. package/dist/neutral/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.d.mts +2 -2
  59. package/dist/neutral/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.d.ts +2 -2
  60. package/dist/neutral/lib/collectionMetrics/lib/probabilityDistributions/index.d.cts +1 -1
  61. package/dist/neutral/lib/collectionMetrics/lib/probabilityDistributions/index.d.mts +1 -1
  62. package/dist/neutral/lib/collectionMetrics/lib/probabilityDistributions/index.d.ts +1 -1
  63. package/dist/neutral/lib/index.d.cts +4 -4
  64. package/dist/neutral/lib/index.d.mts +4 -4
  65. package/dist/neutral/lib/index.d.ts +4 -4
  66. package/dist/neutral/lib/nonEvaluableContractAddresses.d.cts.map +1 -1
  67. package/dist/neutral/lib/nonEvaluableContractAddresses.d.mts.map +1 -1
  68. package/dist/neutral/lib/nonEvaluableContractAddresses.d.ts.map +1 -1
  69. package/dist/node/Plugin.d.cts +1 -1
  70. package/dist/node/Plugin.d.mts +1 -1
  71. package/dist/node/Plugin.d.ts +1 -1
  72. package/dist/node/index.cjs +181 -129
  73. package/dist/node/index.cjs.map +1 -1
  74. package/dist/node/index.d.cts +3 -3
  75. package/dist/node/index.d.mts +3 -3
  76. package/dist/node/index.d.ts +3 -3
  77. package/dist/node/index.mjs +333 -0
  78. package/dist/node/index.mjs.map +1 -0
  79. package/dist/node/lib/collectionMetrics/index.d.cts +1 -1
  80. package/dist/node/lib/collectionMetrics/index.d.mts +1 -1
  81. package/dist/node/lib/collectionMetrics/index.d.ts +1 -1
  82. package/dist/node/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.d.cts +1 -1
  83. package/dist/node/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.d.mts +1 -1
  84. package/dist/node/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.d.ts +1 -1
  85. package/dist/node/lib/collectionMetrics/lib/calculatePropertyDistribution.d.cts +1 -1
  86. package/dist/node/lib/collectionMetrics/lib/calculatePropertyDistribution.d.mts +1 -1
  87. package/dist/node/lib/collectionMetrics/lib/calculatePropertyDistribution.d.ts +1 -1
  88. package/dist/node/lib/collectionMetrics/lib/index.d.cts +3 -3
  89. package/dist/node/lib/collectionMetrics/lib/index.d.mts +3 -3
  90. package/dist/node/lib/collectionMetrics/lib/index.d.ts +3 -3
  91. package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.d.cts +2 -2
  92. package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.d.mts +2 -2
  93. package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.d.ts +2 -2
  94. package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/index.d.cts +1 -1
  95. package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/index.d.mts +1 -1
  96. package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/index.d.ts +1 -1
  97. package/dist/node/lib/index.d.cts +4 -4
  98. package/dist/node/lib/index.d.mts +4 -4
  99. package/dist/node/lib/index.d.ts +4 -4
  100. package/dist/node/lib/nonEvaluableContractAddresses.d.cts.map +1 -1
  101. package/dist/node/lib/nonEvaluableContractAddresses.d.mts.map +1 -1
  102. package/dist/node/lib/nonEvaluableContractAddresses.d.ts.map +1 -1
  103. package/package.json +25 -25
  104. package/src/Plugin.ts +1 -1
  105. package/src/Witness.ts +3 -3
  106. package/src/index.ts +3 -3
  107. package/src/lib/collectionMetrics/getNftCollectionMetrics.ts +3 -3
  108. package/src/lib/collectionMetrics/index.ts +1 -1
  109. package/src/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.ts +1 -1
  110. package/src/lib/collectionMetrics/lib/calculatePropertyDistribution.ts +1 -1
  111. package/src/lib/collectionMetrics/lib/index.ts +3 -3
  112. package/src/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.ts +2 -2
  113. package/src/lib/collectionMetrics/lib/probabilityDistributions/index.ts +1 -1
  114. package/src/lib/getNftCollectionNfts.ts +13 -13
  115. package/src/lib/index.ts +4 -4
  116. package/src/lib/nonEvaluableContractAddresses.ts +1 -1
  117. package/src/lib/tokenTypes.ts +1 -1
  118. package/dist/browser/index.js +0 -279
  119. package/dist/browser/index.js.map +0 -1
  120. package/dist/neutral/index.js +0 -279
  121. package/dist/neutral/index.js.map +0 -1
  122. package/dist/node/index.js +0 -283
  123. package/dist/node/index.js.map +0 -1
@@ -0,0 +1,325 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+
4
+ // src/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.ts
5
+ var calculateAllPropertiesDistribution = /* @__PURE__ */ __name((array) => {
6
+ const distribution = {};
7
+ for (const item of array) {
8
+ for (const property in item) {
9
+ if (Object.prototype.hasOwnProperty.call(item, property)) {
10
+ const value = item[property];
11
+ if (value !== void 0 && value !== null) {
12
+ const valueString = value.toString();
13
+ if (!distribution[property]) {
14
+ distribution[property] = {
15
+ [valueString]: 1
16
+ };
17
+ } else if (distribution[property][valueString]) {
18
+ distribution[property][valueString] += 1;
19
+ } else {
20
+ distribution[property][valueString] = 1;
21
+ }
22
+ }
23
+ }
24
+ }
25
+ }
26
+ return distribution;
27
+ }, "calculateAllPropertiesDistribution");
28
+
29
+ // src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.ts
30
+ var calculateBinomialParamsFromProbability = /* @__PURE__ */ __name((n, p) => {
31
+ const mean = n * p;
32
+ const variance = n * p * (1 - p);
33
+ const stdDev = Math.sqrt(variance);
34
+ return {
35
+ mean,
36
+ p,
37
+ stdDev,
38
+ variance
39
+ };
40
+ }, "calculateBinomialParamsFromProbability");
41
+
42
+ // src/lib/collectionMetrics/getNftCollectionMetrics.ts
43
+ var getNftCollectionMetrics = /* @__PURE__ */ __name((nfts) => {
44
+ const traits = nfts.map((nft) => nft?.metadata?.attributes).filter((v) => v !== void 0).map((attributes2) => {
45
+ return Object.fromEntries(attributes2.map((attribute) => [
46
+ attribute.trait_type,
47
+ attribute.value
48
+ ]));
49
+ });
50
+ const distribution = calculateAllPropertiesDistribution(traits);
51
+ const n = nfts.length;
52
+ const attributes = Object.fromEntries(Object.entries(distribution).filter((v) => v[1] !== void 0).map(([trait, entries]) => {
53
+ const traitCount = Object.values(entries).reduce((prev, curr) => prev + curr, 0);
54
+ const { p } = calculateBinomialParamsFromProbability(nfts.length, traitCount / n);
55
+ const values = Object.fromEntries(Object.entries(entries).map(([value, traitValueCount]) => {
56
+ const { p: p2 } = calculateBinomialParamsFromProbability(n, traitValueCount / n);
57
+ const metrics = {
58
+ binomial: {
59
+ p: p2
60
+ },
61
+ count: traitValueCount
62
+ };
63
+ return [
64
+ value,
65
+ metrics
66
+ ];
67
+ }));
68
+ return [
69
+ trait,
70
+ {
71
+ metrics: {
72
+ binomial: {
73
+ p
74
+ },
75
+ count: traitCount
76
+ },
77
+ values
78
+ }
79
+ ];
80
+ }));
81
+ return {
82
+ metadata: {
83
+ attributes
84
+ }
85
+ };
86
+ }, "getNftCollectionMetrics");
87
+
88
+ // src/lib/contractHasFunctions.ts
89
+ import { assertEx } from "@xylabs/assert";
90
+ var contractHasFunctions = /* @__PURE__ */ __name(async (provider, address, contractInterface, functionNames) => {
91
+ try {
92
+ const bytecode = await provider.getCode(address, "latest");
93
+ for (const functionName of functionNames) {
94
+ const selector = assertEx(contractInterface.getFunction(functionName)?.selector, () => "Function not found on interface");
95
+ if (!bytecode.includes(selector.slice(2))) {
96
+ return false;
97
+ }
98
+ return true;
99
+ }
100
+ return false;
101
+ } catch (ex) {
102
+ const error = ex;
103
+ console.log(error);
104
+ return false;
105
+ }
106
+ }, "contractHasFunctions");
107
+
108
+ // src/lib/getNftCollectionNfts.ts
109
+ import { AxiosJson } from "@xylabs/axios";
110
+ import { exists } from "@xylabs/exists";
111
+ import { isHexZero } from "@xylabs/hex";
112
+ import { NftSchema, toTokenType } from "@xyo-network/crypto-nft-payload-plugin";
113
+ import { getErc1822SlotStatus } from "@xyo-network/erc1822-witness";
114
+ import { getErc1967SlotStatus } from "@xyo-network/erc1967-witness";
115
+ import { ERC721Enumerable__factory, ERC721URIStorage__factory, ERC1155Supply__factory } from "@xyo-network/open-zeppelin-typechain";
116
+ import { checkIpfsUrl } from "@xyo-network/witness-blockchain-abstract";
117
+
118
+ // src/lib/tokenTypes.ts
119
+ import { ERC721__factory, ERC1155URIStorage__factory } from "@xyo-network/open-zeppelin-typechain";
120
+ var isErc1155 = /* @__PURE__ */ __name(async (provider, address) => {
121
+ return await contractHasFunctions(provider, address, ERC1155URIStorage__factory.createInterface(), [
122
+ "uri"
123
+ ]);
124
+ }, "isErc1155");
125
+ var isErc721 = /* @__PURE__ */ __name(async (provider, address) => {
126
+ return await contractHasFunctions(provider, address, ERC721__factory.createInterface(), [
127
+ "name",
128
+ "symbol",
129
+ "tokenURI"
130
+ ]);
131
+ }, "isErc721");
132
+ var tokenTypes = /* @__PURE__ */ __name(async (provider, address) => {
133
+ const [erc721, erc1155] = await Promise.all([
134
+ isErc721(provider, address),
135
+ isErc1155(provider, address)
136
+ ]);
137
+ const result = [];
138
+ if (erc721) {
139
+ result.push("ERC721");
140
+ }
141
+ if (erc1155) {
142
+ result.push("ERC1155");
143
+ }
144
+ return result;
145
+ }, "tokenTypes");
146
+
147
+ // src/lib/tryCall.ts
148
+ var tryCall = /* @__PURE__ */ __name(async (func, name) => {
149
+ try {
150
+ return await func();
151
+ } catch (ex) {
152
+ if (name) {
153
+ const error = ex;
154
+ console.log(`tryCall failed [${name}]: ${error.message}`);
155
+ }
156
+ return void 0;
157
+ }
158
+ }, "tryCall");
159
+
160
+ // src/lib/getNftCollectionNfts.ts
161
+ var ipfsGateway = "5d7b6582.beta.decentralnetworkservices.com";
162
+ function range(size, startAt = 0) {
163
+ return [
164
+ ...Array(size).keys()
165
+ ].map((i) => i + startAt);
166
+ }
167
+ __name(range, "range");
168
+ var getNftCollectionNfts = /* @__PURE__ */ __name(async (contractAddress, provider, types, maxNfts = 100) => {
169
+ try {
170
+ const block = await provider.getBlockNumber();
171
+ const erc1967Status = await getErc1967SlotStatus(provider, contractAddress, block);
172
+ const erc1822Status = await getErc1822SlotStatus(provider, contractAddress, block);
173
+ const implementation = !erc1967Status.slots.implementation || isHexZero(erc1967Status.slots.implementation) ? erc1822Status.implementation : erc1967Status.implementation;
174
+ const axios = new AxiosJson({
175
+ timeout: 2e3
176
+ });
177
+ const enumerable = ERC721Enumerable__factory.connect(implementation, provider);
178
+ const storage = ERC721URIStorage__factory.connect(implementation, provider);
179
+ const supply1155 = ERC1155Supply__factory.connect(implementation, provider);
180
+ const finalTypes = types ?? await tokenTypes(provider, implementation);
181
+ const maxNftsArray = range(maxNfts);
182
+ const result = (await Promise.all(maxNftsArray.map(async (_value, i) => {
183
+ const tokenId = await tryCall(async () => await enumerable.tokenByIndex(i, {
184
+ blockTag: block
185
+ })) ?? BigInt(i);
186
+ if (tokenId !== void 0) {
187
+ const supply = finalTypes.includes(toTokenType("ERC1155")) ? await tryCall(async () => await supply1155["totalSupply(uint256)"](tokenId)) ?? "0x01" : "0x01";
188
+ const metadataUri = await tryCall(async () => await storage.tokenURI(tokenId, {
189
+ blockTag: block
190
+ }));
191
+ const checkedMetaDataUri = metadataUri ? checkIpfsUrl(metadataUri, ipfsGateway) : void 0;
192
+ let metadata;
193
+ if (checkedMetaDataUri !== void 0) {
194
+ try {
195
+ metadata = (await axios.get(checkedMetaDataUri)).data;
196
+ } catch (ex) {
197
+ const error = ex;
198
+ console.error(`Get Metadata failed: ${error.message}`);
199
+ }
200
+ }
201
+ const info = {
202
+ address: contractAddress,
203
+ chainId: Number((await provider.getNetwork()).chainId),
204
+ metadata,
205
+ metadataUri,
206
+ schema: NftSchema,
207
+ supply: `0x${supply.toString(16)}`,
208
+ tokenId: `0x${tokenId.toString(16)}`,
209
+ type: finalTypes.at(0),
210
+ types: finalTypes
211
+ };
212
+ if (implementation !== contractAddress) {
213
+ info.implementation = implementation;
214
+ }
215
+ return info;
216
+ }
217
+ }))).filter(exists);
218
+ return result;
219
+ } catch (ex) {
220
+ const error = ex;
221
+ console.error(`getNftCollectionNfts failed: [${error.name}] ${error.message}`);
222
+ console.log(error.stack);
223
+ return [];
224
+ }
225
+ }, "getNftCollectionNfts");
226
+
227
+ // src/Plugin.ts
228
+ import { NftSchema as NftSchema2 } from "@xyo-network/crypto-nft-payload-plugin";
229
+ import { PayloadSetSchema } from "@xyo-network/payload-model";
230
+ import { createPayloadSetWitnessPlugin } from "@xyo-network/payloadset-plugin";
231
+
232
+ // src/Witness.ts
233
+ import { assertEx as assertEx2 } from "@xylabs/assert";
234
+ import { EthAddress } from "@xylabs/eth-address";
235
+ import { isNftCollectionWitnessQuery, NftCollectionSchema, NftCollectionWitnessConfigSchema } from "@xyo-network/crypto-nft-collection-payload-plugin";
236
+ import { ERC721Enumerable__factory as ERC721Enumerable__factory2 } from "@xyo-network/open-zeppelin-typechain";
237
+ import { PayloadBuilder } from "@xyo-network/payload-builder";
238
+ import { AbstractEvmWitness } from "@xyo-network/witness-evm-abstract";
239
+ var defaultMaxNfts = 100;
240
+ var NoOp = Promise.resolve();
241
+ function resolvedValue(settled, assert) {
242
+ if (assert && settled.status === "rejected") {
243
+ throw settled.reason;
244
+ }
245
+ return settled.status === "fulfilled" ? settled.value : void 0;
246
+ }
247
+ __name(resolvedValue, "resolvedValue");
248
+ var CryptoNftCollectionWitness = class extends AbstractEvmWitness {
249
+ static {
250
+ __name(this, "CryptoNftCollectionWitness");
251
+ }
252
+ static configSchemas = [
253
+ ...super.configSchemas,
254
+ NftCollectionWitnessConfigSchema
255
+ ];
256
+ static defaultConfigSchema = NftCollectionWitnessConfigSchema;
257
+ async observeHandler(payloads) {
258
+ await this.started("throw");
259
+ await this.getProviders();
260
+ const queries = payloads?.filter(isNftCollectionWitnessQuery) ?? [];
261
+ const observations = await Promise.all(queries.map(async (query) => {
262
+ const chainId = assertEx2(query?.chainId || this.config.chainId, () => "params.chainId is required");
263
+ const provider = await this.getProvider(true, true);
264
+ const address = assertEx2(EthAddress.parse(assertEx2(query?.address || this.config.address, () => "params.address is required")), () => "Failed to parse params.address").toString();
265
+ const erc721Enumerable = ERC721Enumerable__factory2.connect(address, provider);
266
+ const maxNfts = query?.maxNfts || defaultMaxNfts;
267
+ const [name, symbol, total, typesSettled, archivistSettled] = await Promise.allSettled([
268
+ erc721Enumerable.name(),
269
+ erc721Enumerable.symbol(),
270
+ erc721Enumerable.totalSupply(),
271
+ tokenTypes(provider, address),
272
+ this.archivistInstance()
273
+ ]);
274
+ const types = resolvedValue(typesSettled, true);
275
+ const nfts = await getNftCollectionNfts(address, provider, types, maxNfts);
276
+ const metrics = getNftCollectionMetrics(nfts);
277
+ const archivist = resolvedValue(archivistSettled);
278
+ const [sources] = await Promise.all([
279
+ // Hash all the payloads
280
+ Promise.all(nfts.map((nft) => PayloadBuilder.dataHash(nft))),
281
+ // Insert them into the archivist if we have one
282
+ archivist ? archivist.insert(nfts) : NoOp
283
+ ]);
284
+ const payload = {
285
+ address,
286
+ chainId,
287
+ metrics,
288
+ name: resolvedValue(name, true),
289
+ schema: NftCollectionSchema,
290
+ sources,
291
+ symbol: resolvedValue(symbol, true),
292
+ total: Number(resolvedValue(total, true)),
293
+ type: types.at(0),
294
+ types
295
+ };
296
+ return payload;
297
+ }));
298
+ return observations.flat();
299
+ }
300
+ };
301
+
302
+ // src/Plugin.ts
303
+ var CryptoNftCollectionWitnessPlugin = /* @__PURE__ */ __name(() => createPayloadSetWitnessPlugin({
304
+ required: {
305
+ [NftSchema2]: 1
306
+ },
307
+ schema: PayloadSetSchema
308
+ }, {
309
+ witness: /* @__PURE__ */ __name(async (params) => {
310
+ const result = await CryptoNftCollectionWitness.create(params);
311
+ return result;
312
+ }, "witness")
313
+ }), "CryptoNftCollectionWitnessPlugin");
314
+ export {
315
+ CryptoNftCollectionWitness,
316
+ CryptoNftCollectionWitnessPlugin,
317
+ contractHasFunctions,
318
+ CryptoNftCollectionWitnessPlugin as default,
319
+ getNftCollectionMetrics,
320
+ getNftCollectionNfts,
321
+ isErc1155,
322
+ isErc721,
323
+ tokenTypes
324
+ };
325
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.ts","../../src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.ts","../../src/lib/collectionMetrics/getNftCollectionMetrics.ts","../../src/lib/contractHasFunctions.ts","../../src/lib/getNftCollectionNfts.ts","../../src/lib/tokenTypes.ts","../../src/lib/tryCall.ts","../../src/Plugin.ts","../../src/Witness.ts"],"sourcesContent":["import { Distribution } from './distribution.ts'\n\nexport const calculateAllPropertiesDistribution = <T>(array: T[]): Distribution<T> => {\n const distribution: Distribution<T> = {}\n\n for (const item of array) {\n for (const property in item) {\n if (Object.prototype.hasOwnProperty.call(item, property)) {\n const value = item[property as keyof T]\n if (value !== undefined && value !== null) {\n const valueString = value.toString()\n if (!distribution[property]) {\n distribution[property] = { [valueString]: 1 }\n } else if (distribution[property]![valueString]) {\n ;(distribution[property] as Record<string, number>)[valueString] += 1\n } else {\n ;(distribution[property] as Record<string, number>)[valueString] = 1\n }\n }\n }\n }\n }\n\n return distribution\n}\n","import { BinomialDistributionParameters } from '@xyo-network/crypto-nft-collection-payload-plugin'\n\n/**\n * Calculates the parameters of a binomial distribution given the number of trials and success probability\n * @param n Number of trials\n * @param p Success probability\n * @returns The binomial distribution parameters\n */\nexport const calculateBinomialParamsFromProbability = (n: number, p: number): BinomialDistributionParameters => {\n // Mean (µ)\n const mean = n * p\n\n // Variance (σ^2)\n const variance = n * p * (1 - p)\n\n // Standard Deviation (σ)\n const stdDev = Math.sqrt(variance)\n\n return { mean, p, stdDev, variance }\n}\n","import { NftCollectionMetrics, NftTraitMetrics } from '@xyo-network/crypto-nft-collection-payload-plugin'\nimport { NftInfoFields, OpenSeaNftAttribute } from '@xyo-network/crypto-nft-payload-plugin'\n\nimport { calculateAllPropertiesDistribution, calculateBinomialParamsFromProbability } from './lib/index.ts'\n\ntype TraitDistributionEntry = [string, { [key: string]: number }]\n\nexport const getNftCollectionMetrics = (nfts: NftInfoFields[]): NftCollectionMetrics => {\n const traits = nfts\n .map(nft => nft?.metadata?.attributes as OpenSeaNftAttribute[] | undefined)\n .filter((v): v is OpenSeaNftAttribute[] => v !== undefined)\n .map((attributes) => {\n return Object.fromEntries(attributes.map(attribute => [attribute.trait_type, attribute.value]))\n })\n const distribution = calculateAllPropertiesDistribution(traits)\n const n = nfts.length\n const attributes = Object.fromEntries(\n Object.entries(distribution)\n .filter((v): v is TraitDistributionEntry => v[1] !== undefined)\n .map(([trait, entries]) => {\n const traitCount = Object.values(entries).reduce((prev, curr) => prev + curr, 0)\n const { p } = calculateBinomialParamsFromProbability(nfts.length, traitCount / n)\n const values = Object.fromEntries(\n Object.entries(entries).map(([value, traitValueCount]) => {\n const { p } = calculateBinomialParamsFromProbability(n, traitValueCount / n)\n const metrics: NftTraitMetrics = { binomial: { p }, count: traitValueCount }\n return [value, metrics]\n }),\n )\n return [trait, { metrics: { binomial: { p }, count: traitCount }, values }]\n }),\n )\n return { metadata: { attributes } }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { Interface, Provider } from 'ethers'\n\nexport const contractHasFunctions = async (provider: Provider, address: string, contractInterface: Interface, functionNames: string[]) => {\n try {\n const bytecode = await provider.getCode(address, 'latest')\n for (const functionName of functionNames) {\n const selector = assertEx(contractInterface.getFunction(functionName)?.selector, () => 'Function not found on interface')\n if (!bytecode.includes(selector.slice(2))) {\n return false\n }\n return true\n }\n return false\n } catch (ex) {\n const error = ex as Error\n console.log(error)\n return false\n }\n}\n","import { AxiosJson } from '@xylabs/axios'\nimport { exists } from '@xylabs/exists'\nimport { isHexZero } from '@xylabs/hex'\nimport { NftInfo, NftMetadata, NftSchema, TokenType, toTokenType } from '@xyo-network/crypto-nft-payload-plugin'\nimport { getErc1822SlotStatus } from '@xyo-network/erc1822-witness'\nimport { getErc1967SlotStatus } from '@xyo-network/erc1967-witness'\nimport { ERC721Enumerable__factory, ERC721URIStorage__factory, ERC1155Supply__factory } from '@xyo-network/open-zeppelin-typechain'\nimport { checkIpfsUrl } from '@xyo-network/witness-blockchain-abstract'\nimport { Provider } from 'ethers'\n\nimport { tokenTypes } from './tokenTypes.ts'\nimport { tryCall } from './tryCall.ts'\n\nconst ipfsGateway = '5d7b6582.beta.decentralnetworkservices.com'\n\nfunction range(size: number, startAt: number = 0): ReadonlyArray<number> {\n return [...Array(size).keys()].map(i => i + startAt)\n}\n\nexport const getNftCollectionNfts = async (\n /**\n * The address of the NFT contract to search for\n */\n contractAddress: string,\n /**\n * The chain ID (1 = Ethereum Mainnet, 4 = Rinkeby, etc.) of the chain to search for NFTs on\n */\n provider: Provider,\n types?: TokenType[],\n /**\n * The maximum number of NFTs to return. Configurable to prevent\n * large wallets from exhausting Infura API credits. Ideally a\n * multiple of 100 as that appears to be the default page size.\n */\n maxNfts = 100,\n): Promise<NftInfo[]> => {\n try {\n const block = await provider.getBlockNumber()\n\n // Check if ERC-1967 Upgradeable\n const erc1967Status = await getErc1967SlotStatus(provider, contractAddress, block)\n\n // Check if ERC-1822 Upgradeable\n const erc1822Status = await getErc1822SlotStatus(provider, contractAddress, block)\n\n const implementation\n = !erc1967Status.slots.implementation || isHexZero(erc1967Status.slots.implementation)\n ? erc1822Status.implementation\n : erc1967Status.implementation\n\n const axios = new AxiosJson({ timeout: 2000 })\n const enumerable = ERC721Enumerable__factory.connect(implementation, provider)\n const storage = ERC721URIStorage__factory.connect(implementation, provider)\n const supply1155 = ERC1155Supply__factory.connect(implementation, provider)\n const finalTypes = types ?? (await tokenTypes(provider, implementation))\n\n const maxNftsArray = range(maxNfts)\n\n const result: NftInfo[] = (\n await Promise.all(\n maxNftsArray.map(async (_value, i) => {\n const tokenId = (await tryCall(async () => await enumerable.tokenByIndex(i, { blockTag: block }))) ?? BigInt(i)\n if (tokenId !== undefined) {\n const supply\n = finalTypes.includes(toTokenType('ERC1155'))\n ? ((await tryCall(async () => await supply1155['totalSupply(uint256)'](tokenId))) ?? '0x01')\n : '0x01'\n const metadataUri = await tryCall(async () => await storage.tokenURI(tokenId, { blockTag: block }))\n const checkedMetaDataUri = metadataUri ? checkIpfsUrl(metadataUri, ipfsGateway) : undefined\n let metadata: NftMetadata | undefined\n if (checkedMetaDataUri !== undefined) {\n try {\n metadata = (await axios.get(checkedMetaDataUri)).data\n } catch (ex) {\n const error = ex as Error\n console.error(`Get Metadata failed: ${error.message}`)\n }\n }\n\n const info: NftInfo = {\n address: contractAddress,\n chainId: Number((await provider.getNetwork()).chainId),\n metadata,\n metadataUri,\n schema: NftSchema,\n supply: `0x${supply.toString(16)}`,\n tokenId: `0x${tokenId.toString(16)}`,\n type: finalTypes.at(0),\n types: finalTypes,\n }\n if (implementation !== contractAddress) {\n info.implementation = implementation\n }\n return info\n }\n }),\n )\n ).filter(exists)\n return result\n } catch (ex) {\n const error = ex as Error\n console.error(`getNftCollectionNfts failed: [${error.name}] ${error.message}`)\n console.log(error.stack)\n return []\n }\n}\n","import { TokenType } from '@xyo-network/crypto-nft-payload-plugin'\nimport { ERC721__factory, ERC1155URIStorage__factory } from '@xyo-network/open-zeppelin-typechain'\nimport { Provider } from 'ethers'\n\nimport { contractHasFunctions } from './contractHasFunctions.ts'\n\nexport const isErc1155 = async (provider: Provider, address: string) => {\n return await contractHasFunctions(provider, address, ERC1155URIStorage__factory.createInterface(), ['uri'])\n}\n\nexport const isErc721 = async (provider: Provider, address: string) => {\n return await contractHasFunctions(provider, address, ERC721__factory.createInterface(), ['name', 'symbol', 'tokenURI'])\n}\n\nexport const tokenTypes = async (provider: Provider, address: string) => {\n const [erc721, erc1155] = await Promise.all([isErc721(provider, address), isErc1155(provider, address)])\n const result: TokenType[] = []\n if (erc721) {\n result.push('ERC721')\n }\n if (erc1155) {\n result.push('ERC1155')\n }\n return result\n}\n","export const tryCall = async <T>(func: () => Promise<T>, name?: string): Promise<T | undefined> => {\n try {\n return await func()\n } catch (ex) {\n if (name) {\n const error = ex as Error\n console.log(`tryCall failed [${name}]: ${error.message}`)\n }\n return undefined\n }\n}\n","import { NftSchema } from '@xyo-network/crypto-nft-payload-plugin'\nimport { PayloadSetSchema } from '@xyo-network/payload-model'\nimport { createPayloadSetWitnessPlugin, PayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin'\n\nimport { CryptoNftCollectionWitness } from './Witness.ts'\n\nexport const CryptoNftCollectionWitnessPlugin = (): PayloadSetWitnessPlugin<CryptoNftCollectionWitness> =>\n createPayloadSetWitnessPlugin<CryptoNftCollectionWitness>(\n { required: { [NftSchema]: 1 }, schema: PayloadSetSchema },\n {\n witness: async (params) => {\n const result = await CryptoNftCollectionWitness.create(params)\n return result\n },\n },\n )\n","import { assertEx } from '@xylabs/assert'\nimport { EthAddress } from '@xylabs/eth-address'\nimport {\n isNftCollectionWitnessQuery,\n NftCollectionInfo,\n NftCollectionSchema,\n NftCollectionWitnessConfig,\n NftCollectionWitnessConfigSchema,\n NftCollectionWitnessQuery,\n} from '@xyo-network/crypto-nft-collection-payload-plugin'\nimport { ERC721Enumerable__factory } from '@xyo-network/open-zeppelin-typechain'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Schema } from '@xyo-network/payload-model'\nimport { AbstractEvmWitness, EvmWitnessParams } from '@xyo-network/witness-evm-abstract'\n\nimport { getNftCollectionMetrics, getNftCollectionNfts, tokenTypes } from './lib/index.ts'\n\nexport type CryptoNftCollectionWitnessParams = EvmWitnessParams<NftCollectionWitnessConfig>\n\nconst defaultMaxNfts = 100\n\n/**\n * A \"no operation\" Promise to be used\n * when no action is desired but a Promise\n * is required to be returned\n */\nconst NoOp = Promise.resolve()\n\nfunction resolvedValue<T>(settled: PromiseSettledResult<T>, assert: true): T\nfunction resolvedValue<T>(settled: PromiseSettledResult<T>, assert?: false): T | undefined\nfunction resolvedValue<T>(settled: PromiseSettledResult<T>, assert?: boolean) {\n if (assert && settled.status === 'rejected') {\n throw settled.reason\n }\n return settled.status === 'fulfilled' ? settled.value : undefined\n}\n\nexport class CryptoNftCollectionWitness<\n TParams extends CryptoNftCollectionWitnessParams = CryptoNftCollectionWitnessParams,\n> extends AbstractEvmWitness<TParams, NftCollectionWitnessQuery, NftCollectionInfo> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, NftCollectionWitnessConfigSchema]\n static override readonly defaultConfigSchema: Schema = NftCollectionWitnessConfigSchema\n\n protected override async observeHandler(payloads?: NftCollectionWitnessQuery[]): Promise<NftCollectionInfo[]> {\n await this.started('throw')\n await this.getProviders() // make sure cache clears\n const queries = payloads?.filter(isNftCollectionWitnessQuery) ?? []\n const observations = await Promise.all(\n queries.map<Promise<NftCollectionInfo>>(async (query) => {\n const chainId = assertEx(query?.chainId || this.config.chainId, () => 'params.chainId is required')\n const provider = await this.getProvider(true, true)\n const address = assertEx(\n EthAddress.parse(assertEx(query?.address || this.config.address, () => 'params.address is required')),\n () => 'Failed to parse params.address',\n ).toString()\n\n const erc721Enumerable = ERC721Enumerable__factory.connect(address, provider)\n\n const maxNfts = query?.maxNfts || defaultMaxNfts\n const [name, symbol, total, typesSettled, archivistSettled] = await Promise.allSettled([\n erc721Enumerable.name(),\n erc721Enumerable.symbol(),\n erc721Enumerable.totalSupply(),\n tokenTypes(provider, address),\n this.archivistInstance(),\n ])\n const types = resolvedValue(typesSettled, true)\n const nfts = await getNftCollectionNfts(address, provider, types, maxNfts)\n const metrics = getNftCollectionMetrics(nfts)\n const archivist = resolvedValue(archivistSettled)\n const [sources] = await Promise.all([\n // Hash all the payloads\n Promise.all(nfts.map(nft => PayloadBuilder.dataHash(nft))),\n // Insert them into the archivist if we have one\n archivist ? archivist.insert(nfts) : NoOp,\n ])\n const payload: NftCollectionInfo = {\n address,\n chainId,\n metrics,\n name: resolvedValue(name, true),\n schema: NftCollectionSchema,\n sources,\n symbol: resolvedValue(symbol, true),\n total: Number(resolvedValue(total, true)),\n type: types.at(0),\n types,\n }\n return payload\n }),\n )\n return observations.flat()\n }\n}\n"],"mappings":";;;;AAEO,IAAMA,qCAAqC,wBAAIC,UAAAA;AACpD,QAAMC,eAAgC,CAAC;AAEvC,aAAWC,QAAQF,OAAO;AACxB,eAAWG,YAAYD,MAAM;AAC3B,UAAIE,OAAOC,UAAUC,eAAeC,KAAKL,MAAMC,QAAAA,GAAW;AACxD,cAAMK,QAAQN,KAAKC,QAAAA;AACnB,YAAIK,UAAUC,UAAaD,UAAU,MAAM;AACzC,gBAAME,cAAcF,MAAMG,SAAQ;AAClC,cAAI,CAACV,aAAaE,QAAAA,GAAW;AAC3BF,yBAAaE,QAAAA,IAAY;cAAE,CAACO,WAAAA,GAAc;YAAE;UAC9C,WAAWT,aAAaE,QAAAA,EAAWO,WAAAA,GAAc;AAC7CT,yBAAaE,QAAAA,EAAqCO,WAAAA,KAAgB;UACtE,OAAO;AACHT,yBAAaE,QAAAA,EAAqCO,WAAAA,IAAe;UACrE;QACF;MACF;IACF;EACF;AAEA,SAAOT;AACT,GAtBkD;;;ACM3C,IAAMW,yCAAyC,wBAACC,GAAWC,MAAAA;AAEhE,QAAMC,OAAOF,IAAIC;AAGjB,QAAME,WAAWH,IAAIC,KAAK,IAAIA;AAG9B,QAAMG,SAASC,KAAKC,KAAKH,QAAAA;AAEzB,SAAO;IAAED;IAAMD;IAAGG;IAAQD;EAAS;AACrC,GAXsD;;;ACD/C,IAAMI,0BAA0B,wBAACC,SAAAA;AACtC,QAAMC,SAASD,KACZE,IAAIC,CAAAA,QAAOA,KAAKC,UAAUC,UAAAA,EAC1BC,OAAO,CAACC,MAAkCA,MAAMC,MAAAA,EAChDN,IAAI,CAACG,gBAAAA;AACJ,WAAOI,OAAOC,YAAYL,YAAWH,IAAIS,CAAAA,cAAa;MAACA,UAAUC;MAAYD,UAAUE;KAAM,CAAA;EAC/F,CAAA;AACF,QAAMC,eAAeC,mCAAmCd,MAAAA;AACxD,QAAMe,IAAIhB,KAAKiB;AACf,QAAMZ,aAAaI,OAAOC,YACxBD,OAAOS,QAAQJ,YAAAA,EACZR,OAAO,CAACC,MAAmCA,EAAE,CAAA,MAAOC,MAAAA,EACpDN,IAAI,CAAC,CAACiB,OAAOD,OAAAA,MAAQ;AACpB,UAAME,aAAaX,OAAOY,OAAOH,OAAAA,EAASI,OAAO,CAACC,MAAMC,SAASD,OAAOC,MAAM,CAAA;AAC9E,UAAM,EAAEC,EAAC,IAAKC,uCAAuC1B,KAAKiB,QAAQG,aAAaJ,CAAAA;AAC/E,UAAMK,SAASZ,OAAOC,YACpBD,OAAOS,QAAQA,OAAAA,EAAShB,IAAI,CAAC,CAACW,OAAOc,eAAAA,MAAgB;AACnD,YAAM,EAAEF,GAAAA,GAAC,IAAKC,uCAAuCV,GAAGW,kBAAkBX,CAAAA;AAC1E,YAAMY,UAA2B;QAAEC,UAAU;UAAEJ,GAAAA;QAAE;QAAGK,OAAOH;MAAgB;AAC3E,aAAO;QAACd;QAAOe;;IACjB,CAAA,CAAA;AAEF,WAAO;MAACT;MAAO;QAAES,SAAS;UAAEC,UAAU;YAAEJ;UAAE;UAAGK,OAAOV;QAAW;QAAGC;MAAO;;EAC3E,CAAA,CAAA;AAEJ,SAAO;IAAEjB,UAAU;MAAEC;IAAW;EAAE;AACpC,GA1BuC;;;ACPvC,SAAS0B,gBAAgB;AAGlB,IAAMC,uBAAuB,8BAAOC,UAAoBC,SAAiBC,mBAA8BC,kBAAAA;AAC5G,MAAI;AACF,UAAMC,WAAW,MAAMJ,SAASK,QAAQJ,SAAS,QAAA;AACjD,eAAWK,gBAAgBH,eAAe;AACxC,YAAMI,WAAWC,SAASN,kBAAkBO,YAAYH,YAAAA,GAAeC,UAAU,MAAM,iCAAA;AACvF,UAAI,CAACH,SAASM,SAASH,SAASI,MAAM,CAAA,CAAA,GAAK;AACzC,eAAO;MACT;AACA,aAAO;IACT;AACA,WAAO;EACT,SAASC,IAAI;AACX,UAAMC,QAAQD;AACdE,YAAQC,IAAIF,KAAAA;AACZ,WAAO;EACT;AACF,GAhBoC;;;ACHpC,SAASG,iBAAiB;AAC1B,SAASC,cAAc;AACvB,SAASC,iBAAiB;AAC1B,SAA+BC,WAAsBC,mBAAmB;AACxE,SAASC,4BAA4B;AACrC,SAASC,4BAA4B;AACrC,SAASC,2BAA2BC,2BAA2BC,8BAA8B;AAC7F,SAASC,oBAAoB;;;ACN7B,SAASC,iBAAiBC,kCAAkC;AAKrD,IAAMC,YAAY,8BAAOC,UAAoBC,YAAAA;AAClD,SAAO,MAAMC,qBAAqBF,UAAUC,SAASE,2BAA2BC,gBAAe,GAAI;IAAC;GAAM;AAC5G,GAFyB;AAIlB,IAAMC,WAAW,8BAAOL,UAAoBC,YAAAA;AACjD,SAAO,MAAMC,qBAAqBF,UAAUC,SAASK,gBAAgBF,gBAAe,GAAI;IAAC;IAAQ;IAAU;GAAW;AACxH,GAFwB;AAIjB,IAAMG,aAAa,8BAAOP,UAAoBC,YAAAA;AACnD,QAAM,CAACO,QAAQC,OAAAA,IAAW,MAAMC,QAAQC,IAAI;IAACN,SAASL,UAAUC,OAAAA;IAAUF,UAAUC,UAAUC,OAAAA;GAAS;AACvG,QAAMW,SAAsB,CAAA;AAC5B,MAAIJ,QAAQ;AACVI,WAAOC,KAAK,QAAA;EACd;AACA,MAAIJ,SAAS;AACXG,WAAOC,KAAK,SAAA;EACd;AACA,SAAOD;AACT,GAV0B;;;ACdnB,IAAME,UAAU,8BAAUC,MAAwBC,SAAAA;AACvD,MAAI;AACF,WAAO,MAAMD,KAAAA;EACf,SAASE,IAAI;AACX,QAAID,MAAM;AACR,YAAME,QAAQD;AACdE,cAAQC,IAAI,mBAAmBJ,IAAAA,MAAUE,MAAMG,OAAO,EAAE;IAC1D;AACA,WAAOC;EACT;AACF,GAVuB;;;AFavB,IAAMC,cAAc;AAEpB,SAASC,MAAMC,MAAcC,UAAkB,GAAC;AAC9C,SAAO;OAAIC,MAAMF,IAAAA,EAAMG,KAAI;IAAIC,IAAIC,CAAAA,MAAKA,IAAIJ,OAAAA;AAC9C;AAFSF;AAIF,IAAMO,uBAAuB,8BAIlCC,iBAIAC,UACAC,OAMAC,UAAU,QAAG;AAEb,MAAI;AACF,UAAMC,QAAQ,MAAMH,SAASI,eAAc;AAG3C,UAAMC,gBAAgB,MAAMC,qBAAqBN,UAAUD,iBAAiBI,KAAAA;AAG5E,UAAMI,gBAAgB,MAAMC,qBAAqBR,UAAUD,iBAAiBI,KAAAA;AAE5E,UAAMM,iBACF,CAACJ,cAAcK,MAAMD,kBAAkBE,UAAUN,cAAcK,MAAMD,cAAc,IACjFF,cAAcE,iBACdJ,cAAcI;AAEpB,UAAMG,QAAQ,IAAIC,UAAU;MAAEC,SAAS;IAAK,CAAA;AAC5C,UAAMC,aAAaC,0BAA0BC,QAAQR,gBAAgBT,QAAAA;AACrE,UAAMkB,UAAUC,0BAA0BF,QAAQR,gBAAgBT,QAAAA;AAClE,UAAMoB,aAAaC,uBAAuBJ,QAAQR,gBAAgBT,QAAAA;AAClE,UAAMsB,aAAarB,SAAU,MAAMsB,WAAWvB,UAAUS,cAAAA;AAExD,UAAMe,eAAejC,MAAMW,OAAAA;AAE3B,UAAMuB,UACJ,MAAMC,QAAQC,IACZH,aAAa5B,IAAI,OAAOgC,QAAQ/B,MAAAA;AAC9B,YAAMgC,UAAW,MAAMC,QAAQ,YAAY,MAAMf,WAAWgB,aAAalC,GAAG;QAAEmC,UAAU7B;MAAM,CAAA,CAAA,KAAQ8B,OAAOpC,CAAAA;AAC7G,UAAIgC,YAAYK,QAAW;AACzB,cAAMC,SACFb,WAAWc,SAASC,YAAY,SAAA,CAAA,IAC5B,MAAMP,QAAQ,YAAY,MAAMV,WAAW,sBAAA,EAAwBS,OAAAA,CAAAA,KAAc,SACnF;AACN,cAAMS,cAAc,MAAMR,QAAQ,YAAY,MAAMZ,QAAQqB,SAASV,SAAS;UAAEG,UAAU7B;QAAM,CAAA,CAAA;AAChG,cAAMqC,qBAAqBF,cAAcG,aAAaH,aAAahD,WAAAA,IAAe4C;AAClF,YAAIQ;AACJ,YAAIF,uBAAuBN,QAAW;AACpC,cAAI;AACFQ,wBAAY,MAAM9B,MAAM+B,IAAIH,kBAAAA,GAAqBI;UACnD,SAASC,IAAI;AACX,kBAAMC,QAAQD;AACdE,oBAAQD,MAAM,wBAAwBA,MAAME,OAAO,EAAE;UACvD;QACF;AAEA,cAAMC,OAAgB;UACpBC,SAASnD;UACToD,SAASC,QAAQ,MAAMpD,SAASqD,WAAU,GAAIF,OAAO;UACrDT;UACAJ;UACAgB,QAAQC;UACRpB,QAAQ,KAAKA,OAAOqB,SAAS,EAAA,CAAA;UAC7B3B,SAAS,KAAKA,QAAQ2B,SAAS,EAAA,CAAA;UAC/BC,MAAMnC,WAAWoC,GAAG,CAAA;UACpBzD,OAAOqB;QACT;AACA,YAAIb,mBAAmBV,iBAAiB;AACtCkD,eAAKxC,iBAAiBA;QACxB;AACA,eAAOwC;MACT;IACF,CAAA,CAAA,GAEFU,OAAOC,MAAAA;AACT,WAAOnC;EACT,SAASoB,IAAI;AACX,UAAMC,QAAQD;AACdE,YAAQD,MAAM,iCAAiCA,MAAMe,IAAI,KAAKf,MAAME,OAAO,EAAE;AAC7ED,YAAQe,IAAIhB,MAAMiB,KAAK;AACvB,WAAO,CAAA;EACT;AACF,GAtFoC;;;AGnBpC,SAASC,aAAAA,kBAAiB;AAC1B,SAASC,wBAAwB;AACjC,SAASC,qCAA8D;;;ACFvE,SAASC,YAAAA,iBAAgB;AACzB,SAASC,kBAAkB;AAC3B,SACEC,6BAEAC,qBAEAC,wCAEK;AACP,SAASC,6BAAAA,kCAAiC;AAC1C,SAASC,sBAAsB;AAE/B,SAASC,0BAA4C;AAMrD,IAAMC,iBAAiB;AAOvB,IAAMC,OAAOC,QAAQC,QAAO;AAI5B,SAASC,cAAiBC,SAAkCC,QAAgB;AAC1E,MAAIA,UAAUD,QAAQE,WAAW,YAAY;AAC3C,UAAMF,QAAQG;EAChB;AACA,SAAOH,QAAQE,WAAW,cAAcF,QAAQI,QAAQC;AAC1D;AALSN;AAOF,IAAMO,6BAAN,cAEGC,mBAAAA;EAvCV,OAuCUA;;;EACR,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,MAAyBE,eAAeC,UAAsE;AAC5G,UAAM,KAAKC,QAAQ,OAAA;AACnB,UAAM,KAAKC,aAAY;AACvB,UAAMC,UAAUH,UAAUI,OAAOC,2BAAAA,KAAgC,CAAA;AACjE,UAAMC,eAAe,MAAMrB,QAAQsB,IACjCJ,QAAQK,IAAgC,OAAOC,UAAAA;AAC7C,YAAMC,UAAUC,UAASF,OAAOC,WAAW,KAAKE,OAAOF,SAAS,MAAM,4BAAA;AACtE,YAAMG,WAAW,MAAM,KAAKC,YAAY,MAAM,IAAA;AAC9C,YAAMC,UAAUJ,UACdK,WAAWC,MAAMN,UAASF,OAAOM,WAAW,KAAKH,OAAOG,SAAS,MAAM,4BAAA,CAAA,GACvE,MAAM,gCAAA,EACNG,SAAQ;AAEV,YAAMC,mBAAmBC,2BAA0BC,QAAQN,SAASF,QAAAA;AAEpE,YAAMS,UAAUb,OAAOa,WAAWvC;AAClC,YAAM,CAACwC,MAAMC,QAAQC,OAAOC,cAAcC,gBAAAA,IAAoB,MAAM1C,QAAQ2C,WAAW;QACrFT,iBAAiBI,KAAI;QACrBJ,iBAAiBK,OAAM;QACvBL,iBAAiBU,YAAW;QAC5BC,WAAWjB,UAAUE,OAAAA;QACrB,KAAKgB,kBAAiB;OACvB;AACD,YAAMC,QAAQ7C,cAAcuC,cAAc,IAAA;AAC1C,YAAMO,OAAO,MAAMC,qBAAqBnB,SAASF,UAAUmB,OAAOV,OAAAA;AAClE,YAAMa,UAAUC,wBAAwBH,IAAAA;AACxC,YAAMI,YAAYlD,cAAcwC,gBAAAA;AAChC,YAAM,CAACW,OAAAA,IAAW,MAAMrD,QAAQsB,IAAI;;QAElCtB,QAAQsB,IAAI0B,KAAKzB,IAAI+B,CAAAA,QAAOC,eAAeC,SAASF,GAAAA,CAAAA,CAAAA;;QAEpDF,YAAYA,UAAUK,OAAOT,IAAAA,IAAQjD;OACtC;AACD,YAAM2D,UAA6B;QACjC5B;QACAL;QACAyB;QACAZ,MAAMpC,cAAcoC,MAAM,IAAA;QAC1BqB,QAAQC;QACRP;QACAd,QAAQrC,cAAcqC,QAAQ,IAAA;QAC9BC,OAAOqB,OAAO3D,cAAcsC,OAAO,IAAA,CAAA;QACnCsB,MAAMf,MAAMgB,GAAG,CAAA;QACfhB;MACF;AACA,aAAOW;IACT,CAAA,CAAA;AAEF,WAAOrC,aAAa2C,KAAI;EAC1B;AACF;;;ADvFO,IAAMC,mCAAmC,6BAC9CC,8BACE;EAAEC,UAAU;IAAE,CAACC,UAAAA,GAAY;EAAE;EAAGC,QAAQC;AAAiB,GACzD;EACEC,SAAS,8BAAOC,WAAAA;AACd,UAAMC,SAAS,MAAMC,2BAA2BC,OAAOH,MAAAA;AACvD,WAAOC;EACT,GAHS;AAIX,CAAA,GAR4C;","names":["calculateAllPropertiesDistribution","array","distribution","item","property","Object","prototype","hasOwnProperty","call","value","undefined","valueString","toString","calculateBinomialParamsFromProbability","n","p","mean","variance","stdDev","Math","sqrt","getNftCollectionMetrics","nfts","traits","map","nft","metadata","attributes","filter","v","undefined","Object","fromEntries","attribute","trait_type","value","distribution","calculateAllPropertiesDistribution","n","length","entries","trait","traitCount","values","reduce","prev","curr","p","calculateBinomialParamsFromProbability","traitValueCount","metrics","binomial","count","assertEx","contractHasFunctions","provider","address","contractInterface","functionNames","bytecode","getCode","functionName","selector","assertEx","getFunction","includes","slice","ex","error","console","log","AxiosJson","exists","isHexZero","NftSchema","toTokenType","getErc1822SlotStatus","getErc1967SlotStatus","ERC721Enumerable__factory","ERC721URIStorage__factory","ERC1155Supply__factory","checkIpfsUrl","ERC721__factory","ERC1155URIStorage__factory","isErc1155","provider","address","contractHasFunctions","ERC1155URIStorage__factory","createInterface","isErc721","ERC721__factory","tokenTypes","erc721","erc1155","Promise","all","result","push","tryCall","func","name","ex","error","console","log","message","undefined","ipfsGateway","range","size","startAt","Array","keys","map","i","getNftCollectionNfts","contractAddress","provider","types","maxNfts","block","getBlockNumber","erc1967Status","getErc1967SlotStatus","erc1822Status","getErc1822SlotStatus","implementation","slots","isHexZero","axios","AxiosJson","timeout","enumerable","ERC721Enumerable__factory","connect","storage","ERC721URIStorage__factory","supply1155","ERC1155Supply__factory","finalTypes","tokenTypes","maxNftsArray","result","Promise","all","_value","tokenId","tryCall","tokenByIndex","blockTag","BigInt","undefined","supply","includes","toTokenType","metadataUri","tokenURI","checkedMetaDataUri","checkIpfsUrl","metadata","get","data","ex","error","console","message","info","address","chainId","Number","getNetwork","schema","NftSchema","toString","type","at","filter","exists","name","log","stack","NftSchema","PayloadSetSchema","createPayloadSetWitnessPlugin","assertEx","EthAddress","isNftCollectionWitnessQuery","NftCollectionSchema","NftCollectionWitnessConfigSchema","ERC721Enumerable__factory","PayloadBuilder","AbstractEvmWitness","defaultMaxNfts","NoOp","Promise","resolve","resolvedValue","settled","assert","status","reason","value","undefined","CryptoNftCollectionWitness","AbstractEvmWitness","configSchemas","NftCollectionWitnessConfigSchema","defaultConfigSchema","observeHandler","payloads","started","getProviders","queries","filter","isNftCollectionWitnessQuery","observations","all","map","query","chainId","assertEx","config","provider","getProvider","address","EthAddress","parse","toString","erc721Enumerable","ERC721Enumerable__factory","connect","maxNfts","name","symbol","total","typesSettled","archivistSettled","allSettled","totalSupply","tokenTypes","archivistInstance","types","nfts","getNftCollectionNfts","metrics","getNftCollectionMetrics","archivist","sources","nft","PayloadBuilder","dataHash","insert","payload","schema","NftCollectionSchema","Number","type","at","flat","CryptoNftCollectionWitnessPlugin","createPayloadSetWitnessPlugin","required","NftSchema","schema","PayloadSetSchema","witness","params","result","CryptoNftCollectionWitness","create"]}
@@ -1,2 +1,2 @@
1
- export * from './getNftCollectionMetrics.js';
1
+ export * from './getNftCollectionMetrics.ts';
2
2
  //# sourceMappingURL=index.d.ts.map
@@ -1,2 +1,2 @@
1
- export * from './getNftCollectionMetrics.js';
1
+ export * from './getNftCollectionMetrics.ts';
2
2
  //# sourceMappingURL=index.d.ts.map
@@ -1,2 +1,2 @@
1
- export * from './getNftCollectionMetrics.js';
1
+ export * from './getNftCollectionMetrics.ts';
2
2
  //# sourceMappingURL=index.d.ts.map
@@ -1,3 +1,3 @@
1
- import { Distribution } from './distribution.js';
1
+ import { Distribution } from './distribution.ts';
2
2
  export declare const calculateAllPropertiesDistribution: <T>(array: T[]) => Distribution<T>;
3
3
  //# sourceMappingURL=calculateAllPropertiesDistribution.d.ts.map
@@ -1,3 +1,3 @@
1
- import { Distribution } from './distribution.js';
1
+ import { Distribution } from './distribution.ts';
2
2
  export declare const calculateAllPropertiesDistribution: <T>(array: T[]) => Distribution<T>;
3
3
  //# sourceMappingURL=calculateAllPropertiesDistribution.d.ts.map
@@ -1,3 +1,3 @@
1
- import { Distribution } from './distribution.js';
1
+ import { Distribution } from './distribution.ts';
2
2
  export declare const calculateAllPropertiesDistribution: <T>(array: T[]) => Distribution<T>;
3
3
  //# sourceMappingURL=calculateAllPropertiesDistribution.d.ts.map
@@ -1,3 +1,3 @@
1
- import { Distribution } from './distribution.js';
1
+ import { Distribution } from './distribution.ts';
2
2
  export declare const calculatePropertyDistribution: <T>(array: T[], property: keyof T) => Distribution<T>;
3
3
  //# sourceMappingURL=calculatePropertyDistribution.d.ts.map
@@ -1,3 +1,3 @@
1
- import { Distribution } from './distribution.js';
1
+ import { Distribution } from './distribution.ts';
2
2
  export declare const calculatePropertyDistribution: <T>(array: T[], property: keyof T) => Distribution<T>;
3
3
  //# sourceMappingURL=calculatePropertyDistribution.d.ts.map
@@ -1,3 +1,3 @@
1
- import { Distribution } from './distribution.js';
1
+ import { Distribution } from './distribution.ts';
2
2
  export declare const calculatePropertyDistribution: <T>(array: T[], property: keyof T) => Distribution<T>;
3
3
  //# sourceMappingURL=calculatePropertyDistribution.d.ts.map
@@ -1,4 +1,4 @@
1
- export * from './calculateAllPropertiesDistribution.js';
2
- export * from './distribution.js';
3
- export * from './probabilityDistributions/index.js';
1
+ export * from './calculateAllPropertiesDistribution.ts';
2
+ export * from './distribution.ts';
3
+ export * from './probabilityDistributions/index.ts';
4
4
  //# sourceMappingURL=index.d.ts.map
@@ -1,4 +1,4 @@
1
- export * from './calculateAllPropertiesDistribution.js';
2
- export * from './distribution.js';
3
- export * from './probabilityDistributions/index.js';
1
+ export * from './calculateAllPropertiesDistribution.ts';
2
+ export * from './distribution.ts';
3
+ export * from './probabilityDistributions/index.ts';
4
4
  //# sourceMappingURL=index.d.ts.map
@@ -1,4 +1,4 @@
1
- export * from './calculateAllPropertiesDistribution.js';
2
- export * from './distribution.js';
3
- export * from './probabilityDistributions/index.js';
1
+ export * from './calculateAllPropertiesDistribution.ts';
2
+ export * from './distribution.ts';
3
+ export * from './probabilityDistributions/index.ts';
4
4
  //# sourceMappingURL=index.d.ts.map
@@ -1,3 +1,3 @@
1
- export * from './calculateBinomialParamsFromOutcomes.js';
2
- export * from './calculateBinomialParamsFromProbability.js';
1
+ export * from './calculateBinomialParamsFromOutcomes.ts';
2
+ export * from './calculateBinomialParamsFromProbability.ts';
3
3
  //# sourceMappingURL=index.d.ts.map
@@ -1,3 +1,3 @@
1
- export * from './calculateBinomialParamsFromOutcomes.js';
2
- export * from './calculateBinomialParamsFromProbability.js';
1
+ export * from './calculateBinomialParamsFromOutcomes.ts';
2
+ export * from './calculateBinomialParamsFromProbability.ts';
3
3
  //# sourceMappingURL=index.d.ts.map
@@ -1,3 +1,3 @@
1
- export * from './calculateBinomialParamsFromOutcomes.js';
2
- export * from './calculateBinomialParamsFromProbability.js';
1
+ export * from './calculateBinomialParamsFromOutcomes.ts';
2
+ export * from './calculateBinomialParamsFromProbability.ts';
3
3
  //# sourceMappingURL=index.d.ts.map
@@ -1,2 +1,2 @@
1
- export * from './binomial/index.js';
1
+ export * from './binomial/index.ts';
2
2
  //# sourceMappingURL=index.d.ts.map
@@ -1,2 +1,2 @@
1
- export * from './binomial/index.js';
1
+ export * from './binomial/index.ts';
2
2
  //# sourceMappingURL=index.d.ts.map
@@ -1,2 +1,2 @@
1
- export * from './binomial/index.js';
1
+ export * from './binomial/index.ts';
2
2
  //# sourceMappingURL=index.d.ts.map
@@ -1,5 +1,5 @@
1
- export * from './collectionMetrics/index.js';
2
- export * from './contractHasFunctions.js';
3
- export * from './getNftCollectionNfts.js';
4
- export * from './tokenTypes.js';
1
+ export * from './collectionMetrics/index.ts';
2
+ export * from './contractHasFunctions.ts';
3
+ export * from './getNftCollectionNfts.ts';
4
+ export * from './tokenTypes.ts';
5
5
  //# sourceMappingURL=index.d.ts.map
@@ -1,5 +1,5 @@
1
- export * from './collectionMetrics/index.js';
2
- export * from './contractHasFunctions.js';
3
- export * from './getNftCollectionNfts.js';
4
- export * from './tokenTypes.js';
1
+ export * from './collectionMetrics/index.ts';
2
+ export * from './contractHasFunctions.ts';
3
+ export * from './getNftCollectionNfts.ts';
4
+ export * from './tokenTypes.ts';
5
5
  //# sourceMappingURL=index.d.ts.map
@@ -1,5 +1,5 @@
1
- export * from './collectionMetrics/index.js';
2
- export * from './contractHasFunctions.js';
3
- export * from './getNftCollectionNfts.js';
4
- export * from './tokenTypes.js';
1
+ export * from './collectionMetrics/index.ts';
2
+ export * from './contractHasFunctions.ts';
3
+ export * from './getNftCollectionNfts.ts';
4
+ export * from './tokenTypes.ts';
5
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"nonEvaluableContractAddresses.d.ts","sourceRoot":"","sources":["../../../src/lib/nonEvaluableContractAddresses.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,6BAA6B,UAGD,CAAA"}
1
+ {"version":3,"file":"nonEvaluableContractAddresses.d.ts","sourceRoot":"","sources":["../../../src/lib/nonEvaluableContractAddresses.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,6BAA6B,UAGH,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"nonEvaluableContractAddresses.d.ts","sourceRoot":"","sources":["../../../src/lib/nonEvaluableContractAddresses.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,6BAA6B,UAGD,CAAA"}
1
+ {"version":3,"file":"nonEvaluableContractAddresses.d.ts","sourceRoot":"","sources":["../../../src/lib/nonEvaluableContractAddresses.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,6BAA6B,UAGH,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"nonEvaluableContractAddresses.d.ts","sourceRoot":"","sources":["../../../src/lib/nonEvaluableContractAddresses.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,6BAA6B,UAGD,CAAA"}
1
+ {"version":3,"file":"nonEvaluableContractAddresses.d.ts","sourceRoot":"","sources":["../../../src/lib/nonEvaluableContractAddresses.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,6BAA6B,UAGH,CAAA"}
@@ -1,4 +1,4 @@
1
1
  import { PayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin';
2
- import { CryptoNftCollectionWitness } from './Witness.js';
2
+ import { CryptoNftCollectionWitness } from './Witness.ts';
3
3
  export declare const CryptoNftCollectionWitnessPlugin: () => PayloadSetWitnessPlugin<CryptoNftCollectionWitness>;
4
4
  //# sourceMappingURL=Plugin.d.ts.map
@@ -1,4 +1,4 @@
1
1
  import { PayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin';
2
- import { CryptoNftCollectionWitness } from './Witness.js';
2
+ import { CryptoNftCollectionWitness } from './Witness.ts';
3
3
  export declare const CryptoNftCollectionWitnessPlugin: () => PayloadSetWitnessPlugin<CryptoNftCollectionWitness>;
4
4
  //# sourceMappingURL=Plugin.d.ts.map
@@ -1,4 +1,4 @@
1
1
  import { PayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin';
2
- import { CryptoNftCollectionWitness } from './Witness.js';
2
+ import { CryptoNftCollectionWitness } from './Witness.ts';
3
3
  export declare const CryptoNftCollectionWitnessPlugin: () => PayloadSetWitnessPlugin<CryptoNftCollectionWitness>;
4
4
  //# sourceMappingURL=Plugin.d.ts.map