@xyo-network/crypto-nft-witness-wallet-plugin 2.99.3 → 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 (55) 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 +168 -132
  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 +358 -0
  10. package/dist/browser/index.mjs.map +1 -0
  11. package/dist/browser/lib/index.d.cts +3 -3
  12. package/dist/browser/lib/index.d.mts +3 -3
  13. package/dist/browser/lib/index.d.ts +3 -3
  14. package/dist/neutral/Plugin.d.cts +1 -1
  15. package/dist/neutral/Plugin.d.mts +1 -1
  16. package/dist/neutral/Plugin.d.ts +1 -1
  17. package/dist/neutral/index.cjs +168 -132
  18. package/dist/neutral/index.cjs.map +1 -1
  19. package/dist/neutral/index.d.cts +3 -3
  20. package/dist/neutral/index.d.mts +3 -3
  21. package/dist/neutral/index.d.ts +3 -3
  22. package/dist/neutral/index.mjs +358 -0
  23. package/dist/neutral/index.mjs.map +1 -0
  24. package/dist/neutral/lib/index.d.cts +3 -3
  25. package/dist/neutral/lib/index.d.mts +3 -3
  26. package/dist/neutral/lib/index.d.ts +3 -3
  27. package/dist/node/Plugin.d.cts +1 -1
  28. package/dist/node/Plugin.d.mts +1 -1
  29. package/dist/node/Plugin.d.ts +1 -1
  30. package/dist/node/index.cjs +173 -134
  31. package/dist/node/index.cjs.map +1 -1
  32. package/dist/node/index.d.cts +3 -3
  33. package/dist/node/index.d.mts +3 -3
  34. package/dist/node/index.d.ts +3 -3
  35. package/dist/node/index.mjs +363 -0
  36. package/dist/node/index.mjs.map +1 -0
  37. package/dist/node/lib/index.d.cts +3 -3
  38. package/dist/node/lib/index.d.mts +3 -3
  39. package/dist/node/lib/index.d.ts +3 -3
  40. package/package.json +42 -42
  41. package/src/Plugin.ts +1 -1
  42. package/src/Witness.ts +6 -6
  43. package/src/index.ts +3 -3
  44. package/src/lib/getNftCollectionMetadata.ts +1 -1
  45. package/src/lib/getNftMetadata.ts +13 -13
  46. package/src/lib/getNftsOwnedByAddress.ts +10 -10
  47. package/src/lib/getProvider.ts +1 -1
  48. package/src/lib/index.ts +3 -3
  49. package/src/lib/tokenTypes.ts +1 -1
  50. package/dist/browser/index.js +0 -324
  51. package/dist/browser/index.js.map +0 -1
  52. package/dist/neutral/index.js +0 -324
  53. package/dist/neutral/index.js.map +0 -1
  54. package/dist/node/index.js +0 -325
  55. package/dist/node/index.js.map +0 -1
@@ -7,9 +7,9 @@ import { checkIpfsUrl } from '@xyo-network/witness-blockchain-abstract'
7
7
  import { Provider } from 'ethers'
8
8
  import parseDataUrl from 'parse-data-url'
9
9
 
10
- import { isErc721, isErc1155 } from './tokenTypes.js'
10
+ import { isErc721, isErc1155 } from './tokenTypes.ts'
11
11
 
12
- /*const baseUrlAbi = [
12
+ /* const baseUrlAbi = [
13
13
  {
14
14
  inputs: [],
15
15
  name: 'baseUrl',
@@ -23,7 +23,7 @@ import { isErc721, isErc1155 } from './tokenTypes.js'
23
23
  stateMutability: 'view',
24
24
  type: 'function',
25
25
  },
26
- ]*/
26
+ ] */
27
27
 
28
28
  const ipfsGateway = '5d7b6582.beta.decentralnetworkservices.com'
29
29
 
@@ -54,12 +54,12 @@ export const getNftMetadata = async (
54
54
  try {
55
55
  uri721 = await storage721.tokenURI(tokenId)
56
56
  } catch {
57
- //const error = ex as Error
58
- //console.error(`metaDataUri[${error.name}][${contractAddress}]: storage721.tokenURI(tokenId) failed`)
57
+ // const error = ex as Error
58
+ // console.error(`metaDataUri[${error.name}][${contractAddress}]: storage721.tokenURI(tokenId) failed`)
59
59
  }
60
60
  }
61
61
 
62
- /*let baseUrl: string | undefined = undefined
62
+ /* let baseUrl: string | undefined = undefined
63
63
  if (is721) {
64
64
  try {
65
65
  const baseUrlContract = new Contract(contractAddress, baseUrlAbi, provider)
@@ -82,9 +82,9 @@ export const getNftMetadata = async (
82
82
  try {
83
83
  uri1155 = await storage1155.uri(tokenId)
84
84
  } catch {
85
- //const error = ex as Error
86
- //console.error(`metaDataUri[${error.name}][${contractAddress}]: storage1155.uri(tokenId) failed`)
87
- //console.log(error.message)
85
+ // const error = ex as Error
86
+ // console.error(`metaDataUri[${error.name}][${contractAddress}]: storage1155.uri(tokenId) failed`)
87
+ // console.log(error.message)
88
88
  }
89
89
  }
90
90
  }
@@ -101,12 +101,12 @@ export const getNftMetadata = async (
101
101
  }
102
102
  } else {
103
103
  let checkedMetaDataUri: string | undefined
104
- /*if (tokenMetadataUri && tokenMetadataUri.length < 5) {
104
+ /* if (tokenMetadataUri && tokenMetadataUri.length < 5) {
105
105
  console.log(`tokenMetadataUri [<5][${contractAddress}]: ${tokenMetadataUri}`)
106
106
  console.log(`tokenMetadataUri [uri721]: ${uri721}`)
107
107
  console.log(`tokenMetadataUri [uri1155]: ${uri1155}`)
108
108
  console.log(`tokenMetadataUri [defaultUri]: ${defaultUri}`)
109
- }*/
109
+ } */
110
110
  const axios = new AxiosJson({ timeout: 5000 })
111
111
  try {
112
112
  if (tokenMetadataUri && tokenMetadataUri.length > 0) {
@@ -117,8 +117,8 @@ export const getNftMetadata = async (
117
117
  try {
118
118
  metadata = defaultUri ? (await axios.get(defaultUri)).data : undefined
119
119
  } catch {
120
- //const error = ex as Error
121
- //console.error(`metadata: ${error.message}`)
120
+ // const error = ex as Error
121
+ // console.error(`metadata: ${error.message}`)
122
122
  }
123
123
  }
124
124
  }
@@ -6,11 +6,11 @@ import { ERC721__factory, ERC1155__factory, ERC1155Supply__factory } from '@xyo-
6
6
  import { Provider } from 'ethers'
7
7
  import { LRUCache } from 'lru-cache'
8
8
 
9
- import { getNftMetadata } from './getNftMetadata.js'
10
- import { getNftsFromWalletFromOpenSea } from './getNftsFromWalletFromOpenSea.js'
11
- import { getProvider } from './getProvider.js'
12
- import { tokenTypes } from './tokenTypes.js'
13
- import { tryCall } from './tryCall.js'
9
+ import { getNftMetadata } from './getNftMetadata.ts'
10
+ import { getNftsFromWalletFromOpenSea } from './getNftsFromWalletFromOpenSea.ts'
11
+ import { getProvider } from './getProvider.ts'
12
+ import { tokenTypes } from './tokenTypes.ts'
13
+ import { tryCall } from './tryCall.ts'
14
14
 
15
15
  const tokenTypeCache = new LRUCache<string, TokenType[]>({ max: 100 })
16
16
 
@@ -104,7 +104,7 @@ export const getNftsOwnedByAddress = async (
104
104
  /** @param httpTimeout The connection timeout for http call to get metadata */
105
105
  timeout = 5000,
106
106
  ): Promise<NftInfoFields[]> => {
107
- //const assets = await getAssetsFromWallet(publicAddress, maxNfts, timeout)
107
+ // const assets = await getAssetsFromWallet(publicAddress, maxNfts, timeout)
108
108
  const nfts = await getNftsFromWalletFromOpenSea(publicAddress, maxNfts, timeout)
109
109
 
110
110
  const nftResult = await Promise.all(
@@ -124,10 +124,10 @@ export const getNftsOwnedByAddress = async (
124
124
  getErc1822SlotStatus(provider, contract, block),
125
125
  ])
126
126
 
127
- const implementation =
128
- !erc1967Status.slots.implementation || isHexZero(erc1967Status.slots.implementation) ?
129
- erc1822Status.implementation
130
- : erc1967Status.implementation
127
+ const implementation
128
+ = !erc1967Status.slots.implementation || isHexZero(erc1967Status.slots.implementation)
129
+ ? erc1822Status.implementation
130
+ : erc1967Status.implementation
131
131
 
132
132
  let supply = 1n
133
133
  const types = await getTokenTypes(provider, implementation)
@@ -1,5 +1,5 @@
1
1
  import { Provider } from 'ethers'
2
2
 
3
3
  export const getProvider = (providers: Provider[]) => {
4
- return providers[Date.now() % providers.length] //pick a random provider
4
+ return providers[Date.now() % providers.length] // pick a random provider
5
5
  }
package/src/lib/index.ts CHANGED
@@ -1,3 +1,3 @@
1
- export * from './contractHasFunctions.js'
2
- export * from './getNftsOwnedByAddress.js'
3
- export * from './tokenTypes.js'
1
+ export * from './contractHasFunctions.ts'
2
+ export * from './getNftsOwnedByAddress.ts'
3
+ export * from './tokenTypes.ts'
@@ -2,7 +2,7 @@ import { TokenType } from '@xyo-network/crypto-nft-payload-plugin'
2
2
  import { ERC1155URIStorage__factory, IERC721Metadata__factory } from '@xyo-network/open-zeppelin-typechain'
3
3
  import { Provider } from 'ethers'
4
4
 
5
- import { contractHasFunctions } from './contractHasFunctions.js'
5
+ import { contractHasFunctions } from './contractHasFunctions.ts'
6
6
 
7
7
  export const isErc1155 = async (provider: Provider, address: string) => {
8
8
  return await contractHasFunctions(provider, address, ERC1155URIStorage__factory.createInterface(), ['uri'])
@@ -1,324 +0,0 @@
1
- // src/lib/contractHasFunctions.ts
2
- import { assertEx } from "@xylabs/assert";
3
- var contractHasFunctions = async (provider, address, contractInterface, functionNames) => {
4
- try {
5
- const bytecode = await provider.getCode(address, "latest");
6
- for (const functionName of functionNames) {
7
- const selector = assertEx(contractInterface.getFunction(functionName)?.selector, () => "Function not found on interface");
8
- if (!bytecode.includes(selector.slice(2))) {
9
- return false;
10
- }
11
- return true;
12
- }
13
- return false;
14
- } catch (ex) {
15
- const error = ex;
16
- console.log(error);
17
- return false;
18
- }
19
- };
20
-
21
- // src/lib/getNftsOwnedByAddress.ts
22
- import { isHexZero } from "@xylabs/hex";
23
- import { getErc1822SlotStatus } from "@xyo-network/erc1822-witness";
24
- import { getErc1967SlotStatus } from "@xyo-network/erc1967-witness";
25
- import { ERC721__factory, ERC1155__factory, ERC1155Supply__factory } from "@xyo-network/open-zeppelin-typechain";
26
- import { LRUCache } from "lru-cache";
27
-
28
- // src/lib/getNftMetadata.ts
29
- import { AxiosJson } from "@xylabs/axios";
30
- import { ERC721URIStorage__factory, ERC1155URIStorage__factory as ERC1155URIStorage__factory2 } from "@xyo-network/open-zeppelin-typechain";
31
- import { checkIpfsUrl } from "@xyo-network/witness-blockchain-abstract";
32
- import parseDataUrl from "parse-data-url";
33
-
34
- // src/lib/tokenTypes.ts
35
- import { ERC1155URIStorage__factory, IERC721Metadata__factory } from "@xyo-network/open-zeppelin-typechain";
36
- var isErc1155 = async (provider, address) => {
37
- return await contractHasFunctions(provider, address, ERC1155URIStorage__factory.createInterface(), ["uri"]);
38
- };
39
- var isErc721 = async (provider, address) => {
40
- return await contractHasFunctions(provider, address, IERC721Metadata__factory.createInterface(), ["name", "symbol", "tokenURI"]);
41
- };
42
- var tokenTypes = async (provider, address) => {
43
- const [erc721, erc1155] = await Promise.all([isErc721(provider, address), isErc1155(provider, address)]);
44
- const result = [];
45
- if (erc721) {
46
- result.push("ERC721");
47
- }
48
- if (erc1155) {
49
- result.push("ERC1155");
50
- }
51
- return result;
52
- };
53
-
54
- // src/lib/getNftMetadata.ts
55
- var ipfsGateway = "5d7b6582.beta.decentralnetworkservices.com";
56
- var getNftMetadata = async (contractAddress, provider, tokenId, load = false, defaultUri) => {
57
- const storage721 = ERC721URIStorage__factory.connect(contractAddress, provider);
58
- const storage1155 = ERC1155URIStorage__factory2.connect(contractAddress, provider);
59
- let uri721 = void 0;
60
- const is721 = await isErc721(provider, contractAddress);
61
- if (is721) {
62
- try {
63
- uri721 = await storage721.tokenURI(tokenId);
64
- } catch {
65
- }
66
- }
67
- let uri1155 = void 0;
68
- if (!uri721) {
69
- const is1155 = await isErc1155(provider, contractAddress);
70
- if (is1155) {
71
- try {
72
- uri1155 = await storage1155.uri(tokenId);
73
- } catch {
74
- }
75
- }
76
- }
77
- const tokenMetadataUri = uri721 || uri1155 || defaultUri;
78
- let metadata = void 0;
79
- if (load) {
80
- if (tokenMetadataUri?.startsWith("data:")) {
81
- const parsedDataUrl = parseDataUrl(tokenMetadataUri);
82
- if (parsedDataUrl !== false && parsedDataUrl.contentType === "application/json") {
83
- const buf = parsedDataUrl.toBuffer();
84
- const value = buf.toString("utf8");
85
- metadata = JSON.parse(value);
86
- }
87
- } else {
88
- let checkedMetaDataUri;
89
- const axios = new AxiosJson({ timeout: 5e3 });
90
- try {
91
- if (tokenMetadataUri && tokenMetadataUri.length > 0) {
92
- checkedMetaDataUri = tokenMetadataUri ? checkIpfsUrl(tokenMetadataUri, ipfsGateway) : tokenMetadataUri;
93
- }
94
- metadata = checkedMetaDataUri ? (await axios.get(checkedMetaDataUri)).data : void 0;
95
- } catch {
96
- try {
97
- metadata = defaultUri ? (await axios.get(defaultUri)).data : void 0;
98
- } catch {
99
- }
100
- }
101
- }
102
- }
103
- return [tokenMetadataUri, metadata];
104
- };
105
-
106
- // src/lib/getNftsFromWalletFromOpenSea.ts
107
- import { assertEx as assertEx2 } from "@xylabs/assert";
108
- import { AxiosJson as AxiosJson2 } from "@xylabs/axios";
109
- var getNftsFromWalletFromOpenSea = async (address, maxNfts = 200, timeout = 2e3) => {
110
- const apiKey = assertEx2(process.env.OPENSEA_API_KEY, () => "No opensea key found");
111
- const axios = new AxiosJson2({ headers: { "x-api-key": apiKey }, timeout });
112
- const nfts = (await axios.get(`https://api.opensea.io/api/v2/chain/ethereum/account/${address}/nfts?limit=${maxNfts}`)).data.nfts;
113
- return nfts;
114
- };
115
-
116
- // src/lib/getProvider.ts
117
- var getProvider = (providers) => {
118
- return providers[Date.now() % providers.length];
119
- };
120
-
121
- // src/lib/tryCall.ts
122
- var tryCall = async (func, name) => {
123
- try {
124
- return await func();
125
- } catch (ex) {
126
- if (name) {
127
- const error = ex;
128
- console.log(`tryCall failed [${name}]: ${error.message}`);
129
- }
130
- return void 0;
131
- }
132
- };
133
-
134
- // src/lib/getNftsOwnedByAddress.ts
135
- var tokenTypeCache = new LRUCache({ max: 100 });
136
- var getTokenTypes = async (provider, address) => {
137
- const key = `${address}|${(await provider.getNetwork()).chainId}`;
138
- const currentValue = tokenTypeCache.get(key);
139
- if (currentValue) {
140
- return currentValue;
141
- } else {
142
- const types = await tokenTypes(provider, address);
143
- tokenTypeCache.set(key, types);
144
- return types;
145
- }
146
- };
147
- var getErc721MetadataUri = async (address, tokenId, provider) => {
148
- try {
149
- const contract = ERC721__factory.connect(address, provider);
150
- return [await contract.tokenURI(tokenId), void 0];
151
- } catch (ex) {
152
- return [void 0, ex];
153
- }
154
- };
155
- var getErc1155MetadataUri = async (address, tokenId, provider) => {
156
- try {
157
- const contract = ERC1155__factory.connect(address, provider);
158
- return [await contract.uri(tokenId), void 0];
159
- } catch (ex) {
160
- return [void 0, ex];
161
- }
162
- };
163
- var getNftMetadataUri = async (address, tokenId, provider) => {
164
- const results = await Promise.all([getErc721MetadataUri(address, tokenId, provider), getErc1155MetadataUri(address, tokenId, provider)]);
165
- return results[0][0] ?? results[1][0];
166
- };
167
- var getNftsOwnedByAddressWithMetadata = async (publicAddress, providers, maxNfts = 200, timeout = 5e3) => {
168
- const nfts = await getNftsOwnedByAddress(publicAddress, providers, maxNfts, timeout);
169
- const nftResult = await Promise.all(
170
- nfts.map(async (nft) => {
171
- try {
172
- if (!nft.metadataUri || !nft.metadata) {
173
- const [metadataUri, metadata] = await getNftMetadata(
174
- nft.implementation ?? nft.address,
175
- getProvider(providers),
176
- nft.tokenId,
177
- true,
178
- nft.metadataUri
179
- );
180
- nft.metadata = nft.metadata ?? metadata;
181
- nft.metadataUri = nft.metadataUri ?? metadataUri;
182
- }
183
- return nft;
184
- } catch (ex) {
185
- const error = ex;
186
- console.error(`Error: ${error.message}`);
187
- console.error(`${error.stack}`);
188
- throw ex;
189
- }
190
- })
191
- );
192
- return nftResult;
193
- };
194
- var getNftsOwnedByAddress = async (publicAddress, providers, maxNfts = 100, timeout = 5e3) => {
195
- const nfts = await getNftsFromWalletFromOpenSea(publicAddress, maxNfts, timeout);
196
- const nftResult = await Promise.all(
197
- nfts.map(async (nft) => {
198
- try {
199
- const { contract, identifier, metadata_url } = nft;
200
- const provider = getProvider(providers);
201
- const block = await provider.getBlockNumber();
202
- const [erc1967Status, erc1822Status] = await Promise.all([
203
- // Check if ERC-1967 Upgradeable
204
- getErc1967SlotStatus(provider, contract, block),
205
- // Check if ERC-1822 Upgradeable
206
- getErc1822SlotStatus(provider, contract, block)
207
- ]);
208
- const implementation = !erc1967Status.slots.implementation || isHexZero(erc1967Status.slots.implementation) ? erc1822Status.implementation : erc1967Status.implementation;
209
- let supply = 1n;
210
- const types = await getTokenTypes(provider, implementation);
211
- if (types.includes("ERC1155")) {
212
- const supply1155 = ERC1155Supply__factory.connect(implementation, getProvider(providers));
213
- supply = await tryCall(async () => await supply1155["totalSupply(uint256)"](erc1967Status.address)) ?? 1n;
214
- }
215
- const fields = {
216
- address: contract,
217
- chainId: Number((await provider.getNetwork()).chainId),
218
- metadataUri: metadata_url ?? void 0,
219
- supply: `0x${supply.toString(16)}`,
220
- tokenId: identifier,
221
- type: types.at(0),
222
- types
223
- };
224
- if (implementation !== contract) {
225
- fields.implementation = implementation;
226
- }
227
- return fields;
228
- } catch (ex) {
229
- const error = ex;
230
- console.error(`Error: ${error.message}`);
231
- console.error(`${error.stack}`);
232
- throw ex;
233
- }
234
- })
235
- );
236
- return nftResult;
237
- };
238
-
239
- // src/Plugin.ts
240
- import { NftSchema as NftSchema2 } from "@xyo-network/crypto-nft-payload-plugin";
241
- import { PayloadSetSchema } from "@xyo-network/payload-model";
242
- import { createPayloadSetWitnessPlugin } from "@xyo-network/payloadset-plugin";
243
-
244
- // src/Witness.ts
245
- import { assertEx as assertEx3 } from "@xylabs/assert";
246
- import { EthAddress } from "@xylabs/eth-address";
247
- import {
248
- isNftWitnessQuery,
249
- NftSchema,
250
- NftWitnessConfigSchema
251
- } from "@xyo-network/crypto-nft-payload-plugin";
252
- import { AbstractEvmWitness } from "@xyo-network/witness-evm-abstract";
253
- var schema = NftSchema;
254
- var defaultMaxNfts = 200;
255
- var CryptoWalletNftWitness = class extends AbstractEvmWitness {
256
- static configSchemas = [...super.configSchemas, NftWitnessConfigSchema];
257
- static defaultConfigSchema = NftWitnessConfigSchema;
258
- get loadMetadata() {
259
- return this.config.loadMetadata ?? true;
260
- }
261
- get timeout() {
262
- return this.config.timeout ?? 1e4;
263
- }
264
- async observeHandler(payloads) {
265
- await this.started("throw");
266
- const queries = payloads?.filter(isNftWitnessQuery) ?? [];
267
- const providers = await this.getProviders();
268
- try {
269
- const observations = await Promise.all(
270
- queries.map(async (query) => {
271
- const provider = await this.getProvider(true, true);
272
- const addressValue = assertEx3(query?.address ?? this.config.address, () => "params.address is required");
273
- const parsedAddressValue = EthAddress.parse(addressValue);
274
- const address = assertEx3(parsedAddressValue?.toString(), () => "Failed to parse params.address");
275
- const network = await provider.getNetwork();
276
- const chainId = assertEx3(network.chainId, () => "params.chainId is required");
277
- const maxNfts = query?.maxNfts || defaultMaxNfts;
278
- try {
279
- const nfts = this.loadMetadata ? await getNftsOwnedByAddressWithMetadata(address, providers, maxNfts, this.timeout) : await getNftsOwnedByAddress(address, providers, maxNfts, this.timeout);
280
- const observation = nfts.map((nft) => {
281
- return { ...nft, schema };
282
- });
283
- return observation;
284
- } catch (ex) {
285
- const error = ex;
286
- throw new Error(`Failed to get nfts for address ${address} on chainId ${chainId}: ${error.message}`);
287
- }
288
- })
289
- );
290
- return observations.flat();
291
- } catch (ex) {
292
- const error = ex;
293
- console.error(error);
294
- return [];
295
- }
296
- }
297
- };
298
-
299
- // src/Plugin.ts
300
- var CryptoWalletNftWitnessPlugin = () => createPayloadSetWitnessPlugin(
301
- { required: { [NftSchema2]: 1 }, schema: PayloadSetSchema },
302
- {
303
- witness: async (params) => {
304
- const result = await CryptoWalletNftWitness.create(params);
305
- return result;
306
- }
307
- }
308
- );
309
- export {
310
- CryptoWalletNftWitness,
311
- CryptoWalletNftWitnessPlugin,
312
- contractHasFunctions,
313
- CryptoWalletNftWitnessPlugin as default,
314
- getErc1155MetadataUri,
315
- getErc721MetadataUri,
316
- getNftMetadataUri,
317
- getNftsOwnedByAddress,
318
- getNftsOwnedByAddressWithMetadata,
319
- getTokenTypes,
320
- isErc1155,
321
- isErc721,
322
- tokenTypes
323
- };
324
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/lib/contractHasFunctions.ts","../../src/lib/getNftsOwnedByAddress.ts","../../src/lib/getNftMetadata.ts","../../src/lib/tokenTypes.ts","../../src/lib/getNftsFromWalletFromOpenSea.ts","../../src/lib/getProvider.ts","../../src/lib/tryCall.ts","../../src/Plugin.ts","../../src/Witness.ts"],"sourcesContent":["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 { isHexZero } from '@xylabs/hex'\nimport { NftInfoFields, TokenType } from '@xyo-network/crypto-nft-payload-plugin'\nimport { getErc1822SlotStatus } from '@xyo-network/erc1822-witness'\nimport { getErc1967SlotStatus } from '@xyo-network/erc1967-witness'\nimport { ERC721__factory, ERC1155__factory, ERC1155Supply__factory } from '@xyo-network/open-zeppelin-typechain'\nimport { Provider } from 'ethers'\nimport { LRUCache } from 'lru-cache'\n\nimport { getNftMetadata } from './getNftMetadata.js'\nimport { getNftsFromWalletFromOpenSea } from './getNftsFromWalletFromOpenSea.js'\nimport { getProvider } from './getProvider.js'\nimport { tokenTypes } from './tokenTypes.js'\nimport { tryCall } from './tryCall.js'\n\nconst tokenTypeCache = new LRUCache<string, TokenType[]>({ max: 100 })\n\nexport const getTokenTypes = async (provider: Provider, address: string) => {\n const key = `${address}|${(await provider.getNetwork()).chainId}`\n const currentValue = tokenTypeCache.get(key)\n if (currentValue) {\n return currentValue\n } else {\n const types = await tokenTypes(provider, address)\n tokenTypeCache.set(key, types)\n return types\n }\n}\n\nexport const getErc721MetadataUri = async (\n address: string,\n tokenId: string,\n provider: Provider,\n): Promise<[string | undefined, Error | undefined]> => {\n try {\n const contract = ERC721__factory.connect(address, provider)\n return [await contract.tokenURI(tokenId), undefined]\n } catch (ex) {\n return [undefined, ex as Error]\n }\n}\n\nexport const getErc1155MetadataUri = async (\n address: string,\n tokenId: string,\n provider: Provider,\n): Promise<[string | undefined, Error | undefined]> => {\n try {\n const contract = ERC1155__factory.connect(address, provider)\n return [await contract.uri(tokenId), undefined]\n } catch (ex) {\n return [undefined, ex as Error]\n }\n}\n\nexport const getNftMetadataUri = async (address: string, tokenId: string, provider: Provider) => {\n const results = await Promise.all([getErc721MetadataUri(address, tokenId, provider), getErc1155MetadataUri(address, tokenId, provider)])\n return results[0][0] ?? results[1][0]\n}\n\nexport const getNftsOwnedByAddressWithMetadata = async (\n /** @param publicAddress The address of the wallet to search for NFTs */\n publicAddress: string,\n /** @param provider The provider to use for accessing the block chain */\n providers: Provider[],\n /** @param maxNfts The maximum number of NFTs to return. Configurable to prevent large wallets from exhausting Infura API credits. */\n maxNfts = 200,\n /** @param httpTimeout The connection timeout for http call to get metadata */\n timeout = 5000,\n): Promise<NftInfoFields[]> => {\n const nfts = await getNftsOwnedByAddress(publicAddress, providers, maxNfts, timeout)\n const nftResult = await Promise.all(\n nfts.map(async (nft) => {\n try {\n if (!nft.metadataUri || !nft.metadata) {\n const [metadataUri, metadata] = await getNftMetadata(\n nft.implementation ?? nft.address,\n getProvider(providers),\n nft.tokenId,\n true,\n nft.metadataUri,\n )\n nft.metadata = nft.metadata ?? metadata\n nft.metadataUri = nft.metadataUri ?? metadataUri\n }\n return nft\n } catch (ex) {\n const error = ex as Error\n console.error(`Error: ${error.message}`)\n console.error(`${error.stack}`)\n throw ex\n }\n }),\n )\n return nftResult\n}\n\nexport const getNftsOwnedByAddress = async (\n /** @param publicAddress The address of the wallet to search for NFTs */\n publicAddress: string,\n /** @param provider The provider to use for accessing the block chain */\n providers: Provider[],\n /** @param maxNfts The maximum number of NFTs to return. Configurable to prevent large wallets from exhausting Infura API credits. */\n maxNfts = 100,\n /** @param httpTimeout The connection timeout for http call to get metadata */\n timeout = 5000,\n): Promise<NftInfoFields[]> => {\n //const assets = await getAssetsFromWallet(publicAddress, maxNfts, timeout)\n const nfts = await getNftsFromWalletFromOpenSea(publicAddress, maxNfts, timeout)\n\n const nftResult = await Promise.all(\n nfts.map(async (nft) => {\n try {\n const { contract, identifier, metadata_url } = nft\n const provider = getProvider(providers)\n\n const block = await provider.getBlockNumber()\n\n // Check if Upgradeable\n const [erc1967Status, erc1822Status] = await Promise.all([\n // Check if ERC-1967 Upgradeable\n getErc1967SlotStatus(provider, contract, block),\n\n // Check if ERC-1822 Upgradeable\n getErc1822SlotStatus(provider, contract, block),\n ])\n\n const implementation =\n !erc1967Status.slots.implementation || isHexZero(erc1967Status.slots.implementation) ?\n erc1822Status.implementation\n : erc1967Status.implementation\n\n let supply = 1n\n const types = await getTokenTypes(provider, implementation)\n if (types.includes('ERC1155')) {\n const supply1155 = ERC1155Supply__factory.connect(implementation, getProvider(providers))\n supply = (await tryCall(async () => await supply1155['totalSupply(uint256)'](erc1967Status.address))) ?? 1n\n }\n const fields: NftInfoFields = {\n address: contract,\n chainId: Number((await provider.getNetwork()).chainId),\n metadataUri: metadata_url ?? undefined,\n supply: `0x${supply.toString(16)}`,\n tokenId: identifier,\n type: types.at(0),\n types,\n }\n if (implementation !== contract) {\n fields.implementation = implementation\n }\n return fields\n } catch (ex) {\n const error = ex as Error\n console.error(`Error: ${error.message}`)\n console.error(`${error.stack}`)\n throw ex\n }\n }),\n )\n\n return nftResult\n}\n","/* eslint-disable complexity */\n\nimport { AxiosJson } from '@xylabs/axios'\nimport { NftMetadata } from '@xyo-network/crypto-nft-payload-plugin'\nimport { ERC721URIStorage__factory, ERC1155URIStorage__factory } from '@xyo-network/open-zeppelin-typechain'\nimport { checkIpfsUrl } from '@xyo-network/witness-blockchain-abstract'\nimport { Provider } from 'ethers'\nimport parseDataUrl from 'parse-data-url'\n\nimport { isErc721, isErc1155 } from './tokenTypes.js'\n\n/*const baseUrlAbi = [\n {\n inputs: [],\n name: 'baseUrl',\n outputs: [\n {\n internalType: 'string',\n name: '',\n type: 'string',\n },\n ],\n stateMutability: 'view',\n type: 'function',\n },\n]*/\n\nconst ipfsGateway = '5d7b6582.beta.decentralnetworkservices.com'\n\nexport const getNftMetadata = 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 /**\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 tokenId: string,\n load = false,\n defaultUri?: string,\n): Promise<[string | undefined, NftMetadata | undefined]> => {\n const storage721 = ERC721URIStorage__factory.connect(contractAddress, provider)\n const storage1155 = ERC1155URIStorage__factory.connect(contractAddress, provider)\n\n let uri721: string | undefined = undefined\n const is721 = await isErc721(provider, contractAddress)\n if (is721) {\n try {\n uri721 = await storage721.tokenURI(tokenId)\n } catch {\n //const error = ex as Error\n //console.error(`metaDataUri[${error.name}][${contractAddress}]: storage721.tokenURI(tokenId) failed`)\n }\n }\n\n /*let baseUrl: string | undefined = undefined\n if (is721) {\n try {\n const baseUrlContract = new Contract(contractAddress, baseUrlAbi, provider)\n baseUrl = await baseUrlContract.bareUrl()\n } catch (ex) {\n const error = ex as Error\n console.error(`baseUrl[${error.name}][${contractAddress}]: baseUrl() failed`)\n }\n }\n\n if (baseUrl && !uri721?.startsWith(baseUrl)) {\n uri721 = `${baseUrl}${uri721 ?? tokenId}`\n }\n */\n\n let uri1155: string | undefined = undefined\n if (!uri721) {\n const is1155 = await isErc1155(provider, contractAddress)\n if (is1155) {\n try {\n uri1155 = await storage1155.uri(tokenId)\n } catch {\n //const error = ex as Error\n //console.error(`metaDataUri[${error.name}][${contractAddress}]: storage1155.uri(tokenId) failed`)\n //console.log(error.message)\n }\n }\n }\n\n const tokenMetadataUri = uri721 || uri1155 || defaultUri\n let metadata: NftMetadata | undefined = undefined\n if (load) {\n if (tokenMetadataUri?.startsWith('data:')) {\n const parsedDataUrl = parseDataUrl(tokenMetadataUri)\n if (parsedDataUrl !== false && parsedDataUrl.contentType === 'application/json') {\n const buf = parsedDataUrl.toBuffer()\n const value = buf.toString('utf8')\n metadata = JSON.parse(value)\n }\n } else {\n let checkedMetaDataUri: string | undefined\n /*if (tokenMetadataUri && tokenMetadataUri.length < 5) {\n console.log(`tokenMetadataUri [<5][${contractAddress}]: ${tokenMetadataUri}`)\n console.log(`tokenMetadataUri [uri721]: ${uri721}`)\n console.log(`tokenMetadataUri [uri1155]: ${uri1155}`)\n console.log(`tokenMetadataUri [defaultUri]: ${defaultUri}`)\n }*/\n const axios = new AxiosJson({ timeout: 5000 })\n try {\n if (tokenMetadataUri && tokenMetadataUri.length > 0) {\n checkedMetaDataUri = tokenMetadataUri ? checkIpfsUrl(tokenMetadataUri, ipfsGateway) : tokenMetadataUri\n }\n metadata = checkedMetaDataUri ? (await axios.get(checkedMetaDataUri)).data : undefined\n } catch {\n try {\n metadata = defaultUri ? (await axios.get(defaultUri)).data : undefined\n } catch {\n //const error = ex as Error\n //console.error(`metadata: ${error.message}`)\n }\n }\n }\n }\n\n return [tokenMetadataUri, metadata]\n}\n","import { TokenType } from '@xyo-network/crypto-nft-payload-plugin'\nimport { ERC1155URIStorage__factory, IERC721Metadata__factory } from '@xyo-network/open-zeppelin-typechain'\nimport { Provider } from 'ethers'\n\nimport { contractHasFunctions } from './contractHasFunctions.js'\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, IERC721Metadata__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","import { assertEx } from '@xylabs/assert'\nimport { AxiosJson } from '@xylabs/axios'\n\ninterface OpenSeaNFT {\n /*\n * Collection slug. A unique string to identify a collection on OpenSea\n */\n collection: string\n /*\n * The unique public blockchain identifier for the contract\n */\n contract: string\n /**\n * @deprecated\n */\n created_at: string\n /*\n * Description of the NFT\n */\n description: string | null\n /*\n * The NFT's unique identifier within the smart contract (also referred to as token_id)\n */\n identifier: string\n /*\n * Link to the image associated with the NFT\n */\n image_url: string | null\n /*\n * If the item is currently able to be bought or sold using OpenSea\n */\n is_disabled: boolean\n /*\n * If the item is currently classified as 'Not Safe for Work' by OpenSea as defined in OpenSea's NSFW Policy.\n */\n is_nsfw: boolean\n /*\n * Link to the offchain metadata store\n */\n metadata_url: string | null\n /*\n * Name of the NFT\n */\n name: string | null\n /*\n * ERC standard of the token (erc721, erc1155)\n */\n token_standard: string\n /*\n * Last time that the NFT's metadata was updated by OpenSea\n */\n updated_at: string\n}\n\nexport const getNftsFromWalletFromOpenSea = async (address: string, maxNfts = 200, timeout = 2000) => {\n const apiKey = assertEx(process.env.OPENSEA_API_KEY, () => 'No opensea key found')\n\n const axios = new AxiosJson({ headers: { 'x-api-key': apiKey }, timeout })\n\n const nfts = (await axios.get<{ nfts: OpenSeaNFT[] }>(`https://api.opensea.io/api/v2/chain/ethereum/account/${address}/nfts?limit=${maxNfts}`)).data\n .nfts\n return nfts\n}\n","import { Provider } from 'ethers'\n\nexport const getProvider = (providers: Provider[]) => {\n return providers[Date.now() % providers.length] //pick a random provider\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 { CryptoWalletNftWitness } from './Witness.js'\n\nexport const CryptoWalletNftWitnessPlugin = (): PayloadSetWitnessPlugin<CryptoWalletNftWitness> =>\n createPayloadSetWitnessPlugin<CryptoWalletNftWitness>(\n { required: { [NftSchema]: 1 }, schema: PayloadSetSchema },\n {\n witness: async (params) => {\n const result = await CryptoWalletNftWitness.create(params)\n return result\n },\n },\n )\n","import { assertEx } from '@xylabs/assert'\nimport { EthAddress } from '@xylabs/eth-address'\nimport {\n CryptoWalletNftWitnessConfig,\n isNftWitnessQuery,\n NftInfo,\n NftSchema,\n NftWitnessConfigSchema,\n NftWitnessQuery,\n} from '@xyo-network/crypto-nft-payload-plugin'\nimport { Schema } from '@xyo-network/payload-model'\nimport { AbstractEvmWitness, EvmWitnessParams } from '@xyo-network/witness-evm-abstract'\n\nimport { getNftsOwnedByAddress, getNftsOwnedByAddressWithMetadata } from './lib/index.js'\n\nexport type CryptoWalletNftWitnessParams = EvmWitnessParams<CryptoWalletNftWitnessConfig>\n\nconst schema = NftSchema\n\nconst defaultMaxNfts = 200\n\nexport class CryptoWalletNftWitness<TParams extends CryptoWalletNftWitnessParams = CryptoWalletNftWitnessParams> extends AbstractEvmWitness<\n TParams,\n NftWitnessQuery,\n NftInfo\n> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, NftWitnessConfigSchema]\n static override readonly defaultConfigSchema: Schema = NftWitnessConfigSchema\n\n get loadMetadata() {\n return this.config.loadMetadata ?? true\n }\n\n get timeout() {\n return this.config.timeout ?? 10_000\n }\n\n protected override async observeHandler(payloads?: NftWitnessQuery[]): Promise<NftInfo[]> {\n await this.started('throw')\n const queries = payloads?.filter(isNftWitnessQuery) ?? []\n //calling it here to make sure we rests the cache\n const providers = await this.getProviders()\n try {\n const observations = await Promise.all(\n queries.map(async (query) => {\n const provider = await this.getProvider(true, true)\n const addressValue = assertEx(query?.address ?? this.config.address, () => 'params.address is required')\n const parsedAddressValue = EthAddress.parse(addressValue)\n const address = assertEx(parsedAddressValue?.toString(), () => 'Failed to parse params.address')\n const network = await provider.getNetwork()\n const chainId = assertEx(network.chainId, () => 'params.chainId is required')\n const maxNfts = query?.maxNfts || defaultMaxNfts\n try {\n const nfts =\n this.loadMetadata ?\n await getNftsOwnedByAddressWithMetadata(address, providers, maxNfts, this.timeout)\n : await getNftsOwnedByAddress(address, providers, maxNfts, this.timeout)\n const observation = nfts.map<NftInfo>((nft) => {\n return { ...nft, schema }\n })\n return observation\n } catch (ex) {\n const error = ex as Error\n throw new Error(`Failed to get nfts for address ${address} on chainId ${chainId}: ${error.message}`)\n }\n }),\n )\n return observations.flat()\n } catch (ex) {\n const error = ex as Error\n console.error(error)\n return []\n }\n }\n}\n"],"mappings":"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","names":["ERC1155URIStorage__factory","ERC1155URIStorage__factory","assertEx","AxiosJson","NftSchema","assertEx","assertEx","NftSchema"]}