@xyo-network/crypto-nft-diviner-score-plugin 6.1.0 → 7.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/neutral/index.mjs +31 -27
- package/dist/neutral/index.mjs.map +2 -2
- package/dist/neutral/lib/rating/criteria/scoring/metadata/attributes/evaluateAttributes.d.ts +2 -2
- package/dist/neutral/lib/rating/criteria/scoring/metadata/attributes/evaluateAttributes.d.ts.map +1 -1
- package/dist/neutral/lib/rating/criteria/scoring/metadata/image.d.ts.map +1 -1
- package/dist/neutral/lib/rating/criteria/scoring/metadata/imageData.d.ts.map +1 -1
- package/package.json +16 -16
package/dist/neutral/index.mjs
CHANGED
|
@@ -27,7 +27,7 @@ import {
|
|
|
27
27
|
// src/lib/rating/criteria/scoring/metadata/lib/urlHelpers.ts
|
|
28
28
|
var web3Protocols = ["ipfs:", "ar:"];
|
|
29
29
|
var toUrl = (url) => {
|
|
30
|
-
if (
|
|
30
|
+
if (url == null || url === "") return void 0;
|
|
31
31
|
try {
|
|
32
32
|
return new URL(url);
|
|
33
33
|
} catch {
|
|
@@ -43,8 +43,8 @@ var scoreNftAnimationUrl = (nft) => {
|
|
|
43
43
|
return scoreAnimationUrl(nft.metadata?.animation_url);
|
|
44
44
|
};
|
|
45
45
|
var scoreAnimationUrl = (animation_url) => {
|
|
46
|
-
const score = [0, 0];
|
|
47
46
|
if (animation_url === void 0 || animation_url === null) return PASS2;
|
|
47
|
+
const score = [0, 0];
|
|
48
48
|
incrementPossible(score);
|
|
49
49
|
if (typeof animation_url !== "string") return score;
|
|
50
50
|
incrementTotalAndPossible(score);
|
|
@@ -62,6 +62,7 @@ import {
|
|
|
62
62
|
incrementTotal as incrementTotal2,
|
|
63
63
|
incrementTotalAndPossible as incrementTotalAndPossible2
|
|
64
64
|
} from "@xyo-network/crypto-nft-score-model";
|
|
65
|
+
var isRecord = (value) => typeof value === "object" && value !== null;
|
|
65
66
|
var isDate = (value) => {
|
|
66
67
|
if (isNumber(value)) {
|
|
67
68
|
try {
|
|
@@ -77,9 +78,9 @@ var isNumber = (value) => typeof value === "number";
|
|
|
77
78
|
var isPercentage = (value) => isNumber(value) && value >= 0 && value <= 100;
|
|
78
79
|
var isNonEmptyString = (value) => typeof value === "string" && value.length > 0;
|
|
79
80
|
var isNonEmptyStringOrNumber = (value) => value === "number" || isNonEmptyString(value);
|
|
80
|
-
var evaluateNftAttributes = (nft) =>
|
|
81
|
+
var evaluateNftAttributes = (nft) => evaluateAttributes(nft?.metadata?.attributes);
|
|
81
82
|
var evaluateAttributes = (attributes) => {
|
|
82
|
-
if (!
|
|
83
|
+
if (!Array.isArray(attributes) || attributes.length === 0) return [0, 1];
|
|
83
84
|
const score = [0, 0];
|
|
84
85
|
for (const attribute of attributes) {
|
|
85
86
|
const [attributeTotal, attributePossible] = evaluateAttribute(attribute);
|
|
@@ -89,10 +90,11 @@ var evaluateAttributes = (attributes) => {
|
|
|
89
90
|
};
|
|
90
91
|
var evaluateAttribute = (attribute) => {
|
|
91
92
|
const score = [0, 1];
|
|
92
|
-
|
|
93
|
-
const
|
|
94
|
-
const
|
|
95
|
-
|
|
93
|
+
if (!isRecord(attribute)) return score;
|
|
94
|
+
const max_value = attribute.max_value;
|
|
95
|
+
const trait_type = attribute.trait_type;
|
|
96
|
+
const value = attribute.value;
|
|
97
|
+
if (!isNonEmptyString(trait_type) || !isNonEmptyStringOrNumber(value)) return score;
|
|
96
98
|
incrementTotal2(score);
|
|
97
99
|
incrementPossible2(score);
|
|
98
100
|
if (validDisplayType(attribute)) incrementTotal2(score);
|
|
@@ -103,23 +105,23 @@ var evaluateAttribute = (attribute) => {
|
|
|
103
105
|
return score;
|
|
104
106
|
};
|
|
105
107
|
var validDisplayType = (attribute) => {
|
|
106
|
-
switch (attribute
|
|
108
|
+
switch (attribute.display_type) {
|
|
107
109
|
case "number":
|
|
108
110
|
case "boost_number": {
|
|
109
|
-
if (isNumber(attribute
|
|
111
|
+
if (isNumber(attribute.value)) return true;
|
|
110
112
|
break;
|
|
111
113
|
}
|
|
112
114
|
case "boost_percentage": {
|
|
113
|
-
if (isPercentage(attribute
|
|
115
|
+
if (isPercentage(attribute.value)) return true;
|
|
114
116
|
break;
|
|
115
117
|
}
|
|
116
118
|
case "date": {
|
|
117
|
-
if (isDate(attribute
|
|
119
|
+
if (isDate(attribute.value)) return true;
|
|
118
120
|
break;
|
|
119
121
|
}
|
|
120
122
|
case "string":
|
|
121
123
|
case void 0: {
|
|
122
|
-
if (isNonEmptyString(attribute
|
|
124
|
+
if (isNonEmptyString(attribute.value)) return true;
|
|
123
125
|
break;
|
|
124
126
|
}
|
|
125
127
|
default: {
|
|
@@ -141,8 +143,8 @@ var scoreNftBackgroundColor = (nft) => {
|
|
|
141
143
|
return scoreBackgroundColor(nft.metadata?.background_color);
|
|
142
144
|
};
|
|
143
145
|
var scoreBackgroundColor = (background_color) => {
|
|
144
|
-
const score = [0, 0];
|
|
145
146
|
if (background_color === void 0 || background_color === null) return PASS3;
|
|
147
|
+
const score = [0, 0];
|
|
146
148
|
incrementPossible3(score);
|
|
147
149
|
if (typeof background_color !== "string") return score;
|
|
148
150
|
incrementTotalAndPossible3(score);
|
|
@@ -157,7 +159,7 @@ var scoreNftDescription = (nft) => {
|
|
|
157
159
|
};
|
|
158
160
|
var scoreDescription = (description) => {
|
|
159
161
|
const score = [0, 1];
|
|
160
|
-
if (
|
|
162
|
+
if (typeof description !== "string" || description.length === 0) return score;
|
|
161
163
|
return incrementTotal4(score);
|
|
162
164
|
};
|
|
163
165
|
|
|
@@ -178,15 +180,16 @@ var scoreExternalUrl = (external_url) => {
|
|
|
178
180
|
import { incrementTotal as incrementTotal6, PASS as PASS4 } from "@xyo-network/crypto-nft-score-model";
|
|
179
181
|
var MaxPossibleImageScore = 3;
|
|
180
182
|
var scoreNftImage = (nft) => {
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
return nft.metadata?.image_data ? PASS4 : [0, MaxPossibleImageScore];
|
|
183
|
+
const image = nft?.metadata?.image;
|
|
184
|
+
if (image != null && image !== "") {
|
|
185
|
+
return scoreImage(image);
|
|
185
186
|
}
|
|
187
|
+
const imageData = nft.metadata?.image_data;
|
|
188
|
+
return imageData != null && imageData !== "" ? PASS4 : [0, MaxPossibleImageScore];
|
|
186
189
|
};
|
|
187
190
|
var scoreImage = (image) => {
|
|
188
191
|
const score = [0, MaxPossibleImageScore];
|
|
189
|
-
if (
|
|
192
|
+
if (typeof image !== "string" || image.length === 0 || !isValidUrl(image)) return score;
|
|
190
193
|
incrementTotal6(score);
|
|
191
194
|
if (!isSecure(image)) return score;
|
|
192
195
|
incrementTotal6(score);
|
|
@@ -209,14 +212,15 @@ var isValidImageData = (image_data) => {
|
|
|
209
212
|
}
|
|
210
213
|
};
|
|
211
214
|
var scoreNftImageData = (nft) => {
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
return nft.metadata?.image ? PASS5 : [0, MaxPossibleImageDataScore];
|
|
215
|
+
const imageData = nft?.metadata?.image_data;
|
|
216
|
+
if (imageData != null && imageData !== "") {
|
|
217
|
+
return scoreImageData(imageData);
|
|
216
218
|
}
|
|
219
|
+
const image = nft.metadata?.image;
|
|
220
|
+
return image != null && image !== "" ? PASS5 : [0, MaxPossibleImageDataScore];
|
|
217
221
|
};
|
|
218
222
|
var scoreImageData = (image_data) => {
|
|
219
|
-
return
|
|
223
|
+
return typeof image_data !== "string" || image_data.length === 0 || !isValidImageData(image_data) ? [0, MaxPossibleImageDataScore] : [MaxPossibleImageDataScore, MaxPossibleImageDataScore];
|
|
220
224
|
};
|
|
221
225
|
|
|
222
226
|
// src/lib/rating/criteria/scoring/metadata/name.ts
|
|
@@ -226,7 +230,7 @@ var scoreNftName = (nft) => {
|
|
|
226
230
|
};
|
|
227
231
|
var scoreName = (name) => {
|
|
228
232
|
const score = [0, 1];
|
|
229
|
-
if (
|
|
233
|
+
if (typeof name !== "string" || name.length === 0) return score;
|
|
230
234
|
return incrementTotal7(score);
|
|
231
235
|
};
|
|
232
236
|
|
|
@@ -271,7 +275,7 @@ var scoreTokenId = (nft) => {
|
|
|
271
275
|
// src/lib/rating/criteria/scoring/type.ts
|
|
272
276
|
import { FAIL as FAIL4, PASS as PASS9 } from "@xyo-network/crypto-nft-score-model";
|
|
273
277
|
var scoreType = (nft) => {
|
|
274
|
-
if (
|
|
278
|
+
if ((nft.types?.length ?? 0) <= 0) return FAIL4;
|
|
275
279
|
if (!Array.isArray(nft.types)) return FAIL4;
|
|
276
280
|
const typesUpper = new Set(nft.types.map((t) => t?.toUpperCase()));
|
|
277
281
|
if (!typesUpper.has("ERC721") && !typesUpper.has("ERC1155")) return FAIL4;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/Diviner.ts", "../../src/lib/rating/criteria/scoring/contract.ts", "../../src/lib/rating/criteria/scoring/metadata/animationUrl.ts", "../../src/lib/rating/criteria/scoring/metadata/lib/urlHelpers.ts", "../../src/lib/rating/criteria/scoring/metadata/attributes/evaluateAttributes.ts", "../../src/lib/rating/criteria/scoring/metadata/backgroundColor.ts", "../../src/lib/rating/criteria/scoring/metadata/description.ts", "../../src/lib/rating/criteria/scoring/metadata/externalUrl.ts", "../../src/lib/rating/criteria/scoring/metadata/image.ts", "../../src/lib/rating/criteria/scoring/metadata/imageData.ts", "../../src/lib/rating/criteria/scoring/metadata/name.ts", "../../src/lib/rating/criteria/scoring/metadata/youtubeUrl.ts", "../../src/lib/rating/criteria/scoring/supply.ts", "../../src/lib/rating/criteria/scoring/tokenId.ts", "../../src/lib/rating/criteria/scoring/type.ts", "../../src/lib/rating/criteria/scoringCriteria.ts", "../../src/lib/rating/analyzeNft.ts", "../../src/Plugin.ts"],
|
|
4
|
-
"sourcesContent": ["import type {\n NftInfo,\n NftScore,\n NftScoreDivinerConfig,\n} from '@xyo-network/crypto-nft-payload-plugin'\nimport {\n isNftInfo,\n NftScoreDivinerConfigSchema,\n NftScoreSchema,\n} from '@xyo-network/crypto-nft-payload-plugin'\nimport type {\n AnyConfigSchema, DivinerParams, Payload, Schema,\n} from '@xyo-network/sdk-js'\nimport { AbstractDiviner, PayloadBuilder } from '@xyo-network/sdk-js'\n\nimport type { NftAnalysis } from './lib/index.ts'\nimport { analyzeNft } from './lib/index.ts'\n\nexport type NftScoreDivinerParams = DivinerParams<AnyConfigSchema<NftScoreDivinerConfig>>\n\nconst toNftScorePayload = (nftInfo: NftInfo, scores: NftAnalysis): NftScore => {\n const {\n\n address, chainId, types,\n } = nftInfo\n return {\n address, chainId, schema: NftScoreSchema, scores, types,\n }\n}\n\nexport const isNftScore = (payload: Payload): payload is NftScore => payload.schema === NftScoreSchema\n\nexport class NftScoreDiviner<TParams extends NftScoreDivinerParams = NftScoreDivinerParams> extends AbstractDiviner<TParams> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, NftScoreDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = NftScoreDivinerConfigSchema\n\n protected override divineHandler = async (payloads?: Payload[]): Promise<Payload[]> => {\n const nftInfos = payloads?.filter(isNftInfo) ?? []\n const results = await Promise.all(\n nftInfos.map<Promise<NftScore>>(async (nftInfo) => {\n const score = toNftScorePayload(nftInfo, await analyzeNft(nftInfo))\n const sourceHash = await PayloadBuilder.dataHash(nftInfo)\n return { ...score, sources: [sourceHash] }\n }),\n )\n return results\n }\n}\n", "import type { NftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { PassFailScoringFunction } from '@xyo-network/crypto-nft-score-model'\nimport { FAIL, PASS } from '@xyo-network/crypto-nft-score-model'\nimport { isAddress } from 'ethers'\n\nexport const scoreContractAddress: PassFailScoringFunction<NftInfoFields> = (nft: NftInfoFields) => {\n if (!nft.address) return FAIL\n if (typeof nft.address !== 'string') return FAIL\n if (!isAddress(nft.address)) return FAIL\n return PASS\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport {\n incrementPossible, incrementTotal, incrementTotalAndPossible, PASS,\n} from '@xyo-network/crypto-nft-score-model'\n\nimport {\n isSecure, isValidUrl, isWeb3,\n} from './lib/index.ts'\n\nexport const scoreNftAnimationUrl = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n return scoreAnimationUrl(nft.metadata?.animation_url)\n}\n\nexport const scoreAnimationUrl = (animation_url: unknown): ScaledScore => {\n const score: ScaledScore = [0, 0]\n if (animation_url === undefined || animation_url === null) return PASS\n incrementPossible(score)\n if (typeof animation_url !== 'string') return score\n incrementTotalAndPossible(score)\n if (!isValidUrl(animation_url)) return score\n incrementTotalAndPossible(score)\n if (!isSecure(animation_url)) return score\n incrementTotalAndPossible(score)\n if (!isWeb3(animation_url)) return score\n return incrementTotal(score)\n}\n", "export const web3Protocols = ['ipfs:', 'ar:']\n\nexport const toUrl = (url?: string | null): URL | undefined => {\n if (!url) return undefined\n try {\n return new URL(url)\n } catch {\n return undefined\n }\n}\n\nexport const isValidUrl = (url?: string | null): boolean => toUrl(url) !== undefined\n// eslint-disable-next-line unicorn/prefer-includes\nexport const isWeb3 = (url?: string | null): boolean => web3Protocols.some(protocol => protocol === toUrl(url)?.protocol)\nexport const isWeb2 = (url?: string | null): boolean => !isWeb3(url)\nexport const isSecure = (url?: string | null): boolean => isWeb3(url) || toUrl(url)?.protocol === 'https:'\n", "import type {\n NftInfoFields, OpenSeaNftAttribute, OpenSeaNftInfoFields,\n} from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport {\n incrementPossible, incrementTotal, incrementTotalAndPossible,\n} from '@xyo-network/crypto-nft-score-model'\n\nconst isDate = (value: unknown): value is Date => {\n if (isNumber(value)) {\n try {\n new Date(value)\n return true\n } catch {\n return false\n }\n }\n return false\n}\n\nconst isNumber = (value: unknown): value is number => typeof value === 'number'\n\nconst isPercentage = (value: unknown): boolean => isNumber(value) && value >= 0 && value <= 100\n\nconst isNonEmptyString = (value: unknown): value is string => typeof value === 'string' && value.length > 0\n\nconst isNonEmptyStringOrNumber = (value: unknown): value is string | number => value === 'number' || isNonEmptyString(value)\n\nexport const evaluateNftAttributes = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore =>\n nft?.metadata?.attributes ? evaluateAttributes(nft?.metadata?.attributes) : [0, 1]\n\nexport const evaluateAttributes = (attributes: unknown): ScaledScore => {\n if (!attributes || !Array.isArray(attributes) || attributes.length === 0) return [0, 1]\n const score: ScaledScore = [0, 0]\n for (const attribute of attributes) {\n const [attributeTotal, attributePossible] = evaluateAttribute(attribute)\n incrementTotalAndPossible(score, attributeTotal, attributePossible)\n }\n return [1, 1]\n}\n\nexport const evaluateAttribute = (attribute: OpenSeaNftAttribute): ScaledScore => {\n const score: ScaledScore = [0, 1]\n const max_value = attribute?.max_value\n const trait_type = attribute?.trait_type\n const value = attribute?.value\n\n // Validate trait_type & value\n if (!attribute || typeof attribute !== 'object' || !isNonEmptyString(trait_type) || !isNonEmptyStringOrNumber(value)) return score\n incrementTotal(score)\n\n // Validate display_type\n incrementPossible(score)\n if (validDisplayType(attribute)) incrementTotal(score)\n\n // Validate max_value\n if (max_value !== undefined) {\n incrementPossible(score)\n if (isNumber(max_value) && isNumber(value) && value <= max_value) incrementTotal(score)\n }\n\n return score\n}\n\nconst validDisplayType = (attribute: OpenSeaNftAttribute): boolean => {\n switch (attribute?.display_type) {\n case 'number':\n case 'boost_number': {\n if (isNumber(attribute?.value)) return true\n break\n }\n case 'boost_percentage': {\n if (isPercentage(attribute?.value)) return true\n break\n }\n case 'date': {\n if (isDate(attribute?.value)) return true\n break\n }\n case 'string':\n case undefined: {\n if (isNonEmptyString(attribute?.value)) return true\n break\n }\n default: {\n break\n }\n }\n return false\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport {\n incrementPossible, incrementTotal, incrementTotalAndPossible, PASS,\n} from '@xyo-network/crypto-nft-score-model'\n\nconst isHexColor = /^[\\da-f]{6}$/i\n\nexport const scoreNftBackgroundColor = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n return scoreBackgroundColor(nft.metadata?.background_color)\n}\n\nexport const scoreBackgroundColor = (background_color: unknown): ScaledScore => {\n const score: ScaledScore = [0, 0]\n if (background_color === undefined || background_color === null) return PASS\n incrementPossible(score)\n if (typeof background_color !== 'string') return score\n incrementTotalAndPossible(score)\n if (!isHexColor.test(background_color.toUpperCase())) return score\n return incrementTotal(score)\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport { incrementTotal } from '@xyo-network/crypto-nft-score-model'\n\nexport const scoreNftDescription = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n return scoreDescription(nft.metadata?.description)\n}\n\nexport const scoreDescription = (description: unknown): ScaledScore => {\n const score: ScaledScore = [0, 1]\n if (!description || typeof description !== 'string') return score\n return incrementTotal(score)\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport { incrementTotal } from '@xyo-network/crypto-nft-score-model'\n\nimport { isSecure, isValidUrl } from './lib/index.ts'\n\nexport const scoreNftExternalUrl = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n return scoreExternalUrl(nft?.metadata?.external_url)\n}\nexport const scoreExternalUrl = (external_url: unknown): ScaledScore => {\n const score: ScaledScore = [0, 2]\n if (external_url === undefined || external_url === null || typeof external_url !== 'string' || !isValidUrl(external_url)) return score\n incrementTotal(score)\n if (!isSecure(external_url)) return score\n return incrementTotal(score)\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport { incrementTotal, PASS } from '@xyo-network/crypto-nft-score-model'\n\nimport {\n isSecure, isValidUrl, isWeb3,\n} from './lib/index.ts'\n\nconst MaxPossibleImageScore = 3\n\nexport const scoreNftImage = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n // If there's no image data\n if (nft?.metadata?.image) {\n return scoreImage(nft.metadata?.image)\n } else {\n // but there is image data, skip this scoring criteria, otherwise fail it completely\n return nft.metadata?.image_data ? PASS : [0, MaxPossibleImageScore]\n }\n}\n\nexport const scoreImage = (image: unknown): ScaledScore => {\n const score: ScaledScore = [0, MaxPossibleImageScore]\n if (!image || typeof image !== 'string' || !isValidUrl(image)) return score\n incrementTotal(score)\n if (!isSecure(image)) return score\n incrementTotal(score)\n if (!isWeb3(image)) return score\n incrementTotal(score)\n return score\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport { PASS } from '@xyo-network/crypto-nft-score-model'\nimport { parse } from 'svg-parser'\n\nconst MaxPossibleImageDataScore = 1\n\n// TODO: There is probably a deeper check we can do\n// here, but this is a good start\nconst isValidImageData = (image_data: string): boolean => {\n // If it doesn't start with an svg tag, it's not an svg\n if (!image_data.startsWith('<svg')) return false\n try {\n // If it can't be parsed, it's not an svg\n parse(image_data)\n return true\n } catch {\n return false\n }\n}\n\nexport const scoreNftImageData = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n // If there's no image data\n if (nft?.metadata?.image_data) {\n return scoreImageData(nft.metadata?.image_data)\n } else {\n // but there is an image, skip this scoring criteria, otherwise fail it completely\n return nft.metadata?.image ? PASS : [0, MaxPossibleImageDataScore]\n }\n}\n\nexport const scoreImageData = (image_data: unknown): ScaledScore => {\n return !image_data || typeof image_data !== 'string' || !isValidImageData(image_data)\n ? [0, MaxPossibleImageDataScore]\n : [MaxPossibleImageDataScore, MaxPossibleImageDataScore]\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport { incrementTotal } from '@xyo-network/crypto-nft-score-model'\n\nexport const scoreNftName = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n return scoreName(nft.metadata?.name)\n}\nexport const scoreName = (name: unknown): ScaledScore => {\n const score: ScaledScore = [0, 1]\n if (!name || typeof name !== 'string') return score\n return incrementTotal(score)\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport { incrementTotal, PASS } from '@xyo-network/crypto-nft-score-model'\n\nimport { isSecure, isValidUrl } from './lib/index.ts'\n\nexport const scoreNftYoutubeUrl = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n return scoreYoutubeUrl(nft?.metadata?.youtube_url)\n}\nexport const scoreYoutubeUrl = (youtube_url: unknown): ScaledScore => {\n if (youtube_url === undefined || youtube_url === null) return PASS\n const score: ScaledScore = [0, 2]\n if (typeof youtube_url !== 'string' || !isValidUrl(youtube_url)) return score\n incrementTotal(score)\n if (!isSecure(youtube_url)) return score\n return incrementTotal(score)\n}\n", "import type { NftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { PassFailScoringFunction } from '@xyo-network/crypto-nft-score-model'\nimport { FAIL, PASS } from '@xyo-network/crypto-nft-score-model'\n\nexport const scoreSupply: PassFailScoringFunction<NftInfoFields> = (nft: NftInfoFields) => {\n if (!nft.supply) return FAIL\n if (typeof nft.supply !== 'string') return FAIL\n try {\n return BigInt(nft.tokenId) >= 0n && BigInt(nft.tokenId) < 2n ** 256n ? PASS : FAIL\n } catch {\n return FAIL\n }\n}\n", "import type { NftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { PassFailScoringFunction } from '@xyo-network/crypto-nft-score-model'\nimport { FAIL, PASS } from '@xyo-network/crypto-nft-score-model'\n\n/**\n * Callers SHALL NOT assume that ID numbers have any specific pattern to them, and\n * MUST treat the ID as a \"black box\"\n * @param nft\n * @returns\n */\nexport const scoreTokenId: PassFailScoringFunction<NftInfoFields> = (nft: NftInfoFields) => {\n if (!nft.tokenId) return FAIL\n if (typeof nft.tokenId !== 'string') return FAIL\n try {\n return BigInt(nft.tokenId) >= 0n && BigInt(nft.tokenId) < 2n ** 256n ? PASS : FAIL\n } catch {\n return FAIL\n }\n}\n", "import type { NftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { PassFailScoringFunction } from '@xyo-network/crypto-nft-score-model'\nimport { FAIL, PASS } from '@xyo-network/crypto-nft-score-model'\n\nexport const scoreType: PassFailScoringFunction<NftInfoFields> = (nft: NftInfoFields) => {\n if (!((nft.types?.length ?? 0) > 0)) return FAIL\n if (!Array.isArray(nft.types)) return FAIL\n const typesUpper = new Set(nft.types.map(t => t?.toUpperCase()))\n if (!typesUpper.has('ERC721') && !typesUpper.has('ERC1155')) return FAIL\n return PASS\n}\n", "import {\n evaluateNftAttributes,\n scoreContractAddress,\n scoreNftAnimationUrl,\n scoreNftBackgroundColor,\n scoreNftDescription,\n scoreNftExternalUrl,\n scoreNftImage,\n scoreNftImageData,\n scoreNftName,\n scoreNftYoutubeUrl,\n scoreSupply,\n scoreTokenId,\n scoreType,\n} from './scoring/index.ts'\n\nconst attributesScoringCriteria = { Attributes: { score: evaluateNftAttributes, weight: 1 } }\n\nconst metadataScoringCriteria = {\n 'Animation URL': { score: scoreNftAnimationUrl, weight: 1 },\n 'Background Color': { score: scoreNftBackgroundColor, weight: 1 },\n 'Description': { score: scoreNftDescription, weight: 1 },\n 'External Url': { score: scoreNftExternalUrl, weight: 1 },\n 'Image': { score: scoreNftImage, weight: 1 },\n 'Image Data': { score: scoreNftImageData, weight: 1 },\n 'Name': { score: scoreNftName, weight: 1 },\n 'YouTube URL': { score: scoreNftYoutubeUrl, weight: 1 },\n ...attributesScoringCriteria,\n}\n\nexport const scoringCriteria = {\n 'Contract Address': { score: scoreContractAddress, weight: 1 },\n 'Supply': { score: scoreSupply, weight: 1 },\n 'Token Id': { score: scoreTokenId, weight: 1 },\n 'Type': { score: scoreType, weight: 1 },\n ...metadataScoringCriteria,\n}\n", "import type { NftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { Score } from '@xyo-network/crypto-nft-score-model'\n\nimport { scoringCriteria } from './criteria/index.ts'\n\nexport type ScoringCriteriaKey = keyof typeof scoringCriteria\n\nexport type NftAnalysis = Record<ScoringCriteriaKey, Score>\n\nexport const analyzeNft = async (\n /**\n * The NFT to evaluate\n */\n nft: NftInfoFields,\n): Promise<NftAnalysis> => {\n const result = Object.fromEntries(\n await Promise.all(\n Object.entries(scoringCriteria).map(async ([key, { score, weight }]) => {\n const rawScore = await score(nft)\n const weighted = rawScore.map(v => v * weight) as Score\n return [key, weighted] as const\n }),\n ),\n ) as NftAnalysis\n return result\n}\n", "import { NftSchema } from '@xyo-network/crypto-nft-payload-plugin'\nimport { createPayloadSetDivinerPlugin, PayloadSetSchema } from '@xyo-network/sdk-js'\n\nimport { NftScoreDiviner } from './Diviner.ts'\n\nexport const NftScoreDivinerPlugin = () =>\n createPayloadSetDivinerPlugin<NftScoreDiviner>(\n { required: { [NftSchema]: 1 }, schema: PayloadSetSchema },\n {\n diviner: async (params) => {\n const result = await NftScoreDiviner.create(params)\n return result\n },\n },\n )\n"],
|
|
5
|
-
"mappings": ";AAKA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAIP,SAAS,iBAAiB,sBAAsB;;;ACXhD,SAAS,MAAM,YAAY;AAC3B,SAAS,iBAAiB;AAEnB,IAAM,uBAA+D,CAAC,QAAuB;AAClG,MAAI,CAAC,IAAI,QAAS,QAAO;AACzB,MAAI,OAAO,IAAI,YAAY,SAAU,QAAO;AAC5C,MAAI,CAAC,UAAU,IAAI,OAAO,EAAG,QAAO;AACpC,SAAO;AACT;;;ACRA;AAAA,EACE;AAAA,EAAmB;AAAA,EAAgB;AAAA,EAA2B,QAAAA;AAAA,OACzD;;;ACJA,IAAM,gBAAgB,CAAC,SAAS,KAAK;AAErC,IAAM,QAAQ,CAAC,QAAyC;AAC7D,MAAI,
|
|
4
|
+
"sourcesContent": ["import type {\n NftInfo,\n NftScore,\n NftScoreDivinerConfig,\n} from '@xyo-network/crypto-nft-payload-plugin'\nimport {\n isNftInfo,\n NftScoreDivinerConfigSchema,\n NftScoreSchema,\n} from '@xyo-network/crypto-nft-payload-plugin'\nimport type {\n AnyConfigSchema, DivinerParams, Payload, Schema,\n} from '@xyo-network/sdk-js'\nimport { AbstractDiviner, PayloadBuilder } from '@xyo-network/sdk-js'\n\nimport type { NftAnalysis } from './lib/index.ts'\nimport { analyzeNft } from './lib/index.ts'\n\nexport type NftScoreDivinerParams = DivinerParams<AnyConfigSchema<NftScoreDivinerConfig>>\n\nconst toNftScorePayload = (nftInfo: NftInfo, scores: NftAnalysis): NftScore => {\n const {\n\n address, chainId, types,\n } = nftInfo\n return {\n address, chainId, schema: NftScoreSchema, scores, types,\n }\n}\n\nexport const isNftScore = (payload: Payload): payload is NftScore => payload.schema === NftScoreSchema\n\nexport class NftScoreDiviner<TParams extends NftScoreDivinerParams = NftScoreDivinerParams> extends AbstractDiviner<TParams> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, NftScoreDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = NftScoreDivinerConfigSchema\n\n protected override divineHandler = async (payloads?: Payload[]): Promise<Payload[]> => {\n const nftInfos = payloads?.filter(isNftInfo) ?? []\n const results = await Promise.all(\n nftInfos.map<Promise<NftScore>>(async (nftInfo) => {\n const score = toNftScorePayload(nftInfo, await analyzeNft(nftInfo))\n const sourceHash = await PayloadBuilder.dataHash(nftInfo)\n return { ...score, sources: [sourceHash] }\n }),\n )\n return results\n }\n}\n", "import type { NftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { PassFailScoringFunction } from '@xyo-network/crypto-nft-score-model'\nimport { FAIL, PASS } from '@xyo-network/crypto-nft-score-model'\nimport { isAddress } from 'ethers'\n\nexport const scoreContractAddress: PassFailScoringFunction<NftInfoFields> = (nft: NftInfoFields) => {\n if (!nft.address) return FAIL\n if (typeof nft.address !== 'string') return FAIL\n if (!isAddress(nft.address)) return FAIL\n return PASS\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport {\n incrementPossible, incrementTotal, incrementTotalAndPossible, PASS,\n} from '@xyo-network/crypto-nft-score-model'\n\nimport {\n isSecure, isValidUrl, isWeb3,\n} from './lib/index.ts'\n\nexport const scoreNftAnimationUrl = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n return scoreAnimationUrl(nft.metadata?.animation_url)\n}\n\nexport const scoreAnimationUrl = (animation_url: unknown): ScaledScore => {\n if (animation_url === undefined || animation_url === null) return PASS\n const score: ScaledScore = [0, 0]\n incrementPossible(score)\n if (typeof animation_url !== 'string') return score\n incrementTotalAndPossible(score)\n if (!isValidUrl(animation_url)) return score\n incrementTotalAndPossible(score)\n if (!isSecure(animation_url)) return score\n incrementTotalAndPossible(score)\n if (!isWeb3(animation_url)) return score\n return incrementTotal(score)\n}\n", "export const web3Protocols = ['ipfs:', 'ar:']\n\nexport const toUrl = (url?: string | null): URL | undefined => {\n if (url == null || url === '') return undefined\n try {\n return new URL(url)\n } catch {\n return undefined\n }\n}\n\nexport const isValidUrl = (url?: string | null): boolean => toUrl(url) !== undefined\n// eslint-disable-next-line unicorn/prefer-includes\nexport const isWeb3 = (url?: string | null): boolean => web3Protocols.some(protocol => protocol === toUrl(url)?.protocol)\nexport const isWeb2 = (url?: string | null): boolean => !isWeb3(url)\nexport const isSecure = (url?: string | null): boolean => isWeb3(url) || toUrl(url)?.protocol === 'https:'\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport {\n incrementPossible, incrementTotal, incrementTotalAndPossible,\n} from '@xyo-network/crypto-nft-score-model'\n\nconst isRecord = (value: unknown): value is Record<string, unknown> => typeof value === 'object' && value !== null\n\nconst isDate = (value: unknown): value is Date => {\n if (isNumber(value)) {\n try {\n new Date(value)\n return true\n } catch {\n return false\n }\n }\n return false\n}\n\nconst isNumber = (value: unknown): value is number => typeof value === 'number'\n\nconst isPercentage = (value: unknown): boolean => isNumber(value) && value >= 0 && value <= 100\n\nconst isNonEmptyString = (value: unknown): value is string => typeof value === 'string' && value.length > 0\n\nconst isNonEmptyStringOrNumber = (value: unknown): value is string | number => value === 'number' || isNonEmptyString(value)\n\nexport const evaluateNftAttributes = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore =>\n evaluateAttributes(nft?.metadata?.attributes)\n\nexport const evaluateAttributes = (attributes: unknown): ScaledScore => {\n if (!Array.isArray(attributes) || attributes.length === 0) return [0, 1]\n const score: ScaledScore = [0, 0]\n for (const attribute of attributes) {\n const [attributeTotal, attributePossible] = evaluateAttribute(attribute)\n incrementTotalAndPossible(score, attributeTotal, attributePossible)\n }\n return [1, 1]\n}\n\nexport const evaluateAttribute = (attribute: unknown): ScaledScore => {\n const score: ScaledScore = [0, 1]\n\n // Validate trait_type & value\n if (!isRecord(attribute)) return score\n const max_value = attribute.max_value\n const trait_type = attribute.trait_type\n const value = attribute.value\n if (!isNonEmptyString(trait_type) || !isNonEmptyStringOrNumber(value)) return score\n incrementTotal(score)\n\n // Validate display_type\n incrementPossible(score)\n if (validDisplayType(attribute)) incrementTotal(score)\n\n // Validate max_value\n if (max_value !== undefined) {\n incrementPossible(score)\n if (isNumber(max_value) && isNumber(value) && value <= max_value) incrementTotal(score)\n }\n\n return score\n}\n\nconst validDisplayType = (attribute: Record<string, unknown>): boolean => {\n switch (attribute.display_type) {\n case 'number':\n case 'boost_number': {\n if (isNumber(attribute.value)) return true\n break\n }\n case 'boost_percentage': {\n if (isPercentage(attribute.value)) return true\n break\n }\n case 'date': {\n if (isDate(attribute.value)) return true\n break\n }\n case 'string':\n case undefined: {\n if (isNonEmptyString(attribute.value)) return true\n break\n }\n default: {\n break\n }\n }\n return false\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport {\n incrementPossible, incrementTotal, incrementTotalAndPossible, PASS,\n} from '@xyo-network/crypto-nft-score-model'\n\nconst isHexColor = /^[\\da-f]{6}$/i\n\nexport const scoreNftBackgroundColor = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n return scoreBackgroundColor(nft.metadata?.background_color)\n}\n\nexport const scoreBackgroundColor = (background_color: unknown): ScaledScore => {\n if (background_color === undefined || background_color === null) return PASS\n const score: ScaledScore = [0, 0]\n incrementPossible(score)\n if (typeof background_color !== 'string') return score\n incrementTotalAndPossible(score)\n if (!isHexColor.test(background_color.toUpperCase())) return score\n return incrementTotal(score)\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport { incrementTotal } from '@xyo-network/crypto-nft-score-model'\n\nexport const scoreNftDescription = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n return scoreDescription(nft.metadata?.description)\n}\n\nexport const scoreDescription = (description: unknown): ScaledScore => {\n const score: ScaledScore = [0, 1]\n if (typeof description !== 'string' || description.length === 0) return score\n return incrementTotal(score)\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport { incrementTotal } from '@xyo-network/crypto-nft-score-model'\n\nimport { isSecure, isValidUrl } from './lib/index.ts'\n\nexport const scoreNftExternalUrl = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n return scoreExternalUrl(nft?.metadata?.external_url)\n}\nexport const scoreExternalUrl = (external_url: unknown): ScaledScore => {\n const score: ScaledScore = [0, 2]\n if (external_url === undefined || external_url === null || typeof external_url !== 'string' || !isValidUrl(external_url)) return score\n incrementTotal(score)\n if (!isSecure(external_url)) return score\n return incrementTotal(score)\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport { incrementTotal, PASS } from '@xyo-network/crypto-nft-score-model'\n\nimport {\n isSecure, isValidUrl, isWeb3,\n} from './lib/index.ts'\n\nconst MaxPossibleImageScore = 3\n\nexport const scoreNftImage = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n const image = nft?.metadata?.image\n // If there is image data\n if (image != null && image !== '') {\n return scoreImage(image)\n }\n // but there is no image data, skip this scoring criteria if image_data is present, otherwise fail it completely\n const imageData = nft.metadata?.image_data\n return imageData != null && imageData !== '' ? PASS : [0, MaxPossibleImageScore]\n}\n\nexport const scoreImage = (image: unknown): ScaledScore => {\n const score: ScaledScore = [0, MaxPossibleImageScore]\n if (typeof image !== 'string' || image.length === 0 || !isValidUrl(image)) return score\n incrementTotal(score)\n if (!isSecure(image)) return score\n incrementTotal(score)\n if (!isWeb3(image)) return score\n incrementTotal(score)\n return score\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport { PASS } from '@xyo-network/crypto-nft-score-model'\nimport { parse } from 'svg-parser'\n\nconst MaxPossibleImageDataScore = 1\n\n// TODO: There is probably a deeper check we can do\n// here, but this is a good start\nconst isValidImageData = (image_data: string): boolean => {\n // If it doesn't start with an SVG tag, it's not an SVG\n if (!image_data.startsWith('<svg')) return false\n try {\n // If it can't be parsed, it's not an SVG\n parse(image_data)\n return true\n } catch {\n return false\n }\n}\n\nexport const scoreNftImageData = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n const imageData = nft?.metadata?.image_data\n // If there is image data\n if (imageData != null && imageData !== '') {\n return scoreImageData(imageData)\n }\n // but there is no image data, skip this scoring criteria if an image is present, otherwise fail it completely\n const image = nft.metadata?.image\n return image != null && image !== '' ? PASS : [0, MaxPossibleImageDataScore]\n}\n\nexport const scoreImageData = (image_data: unknown): ScaledScore => {\n return typeof image_data !== 'string' || image_data.length === 0 || !isValidImageData(image_data)\n ? [0, MaxPossibleImageDataScore]\n : [MaxPossibleImageDataScore, MaxPossibleImageDataScore]\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport { incrementTotal } from '@xyo-network/crypto-nft-score-model'\n\nexport const scoreNftName = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n return scoreName(nft.metadata?.name)\n}\nexport const scoreName = (name: unknown): ScaledScore => {\n const score: ScaledScore = [0, 1]\n if (typeof name !== 'string' || name.length === 0) return score\n return incrementTotal(score)\n}\n", "import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { ScaledScore } from '@xyo-network/crypto-nft-score-model'\nimport { incrementTotal, PASS } from '@xyo-network/crypto-nft-score-model'\n\nimport { isSecure, isValidUrl } from './lib/index.ts'\n\nexport const scoreNftYoutubeUrl = (nft: NftInfoFields | OpenSeaNftInfoFields): ScaledScore => {\n return scoreYoutubeUrl(nft?.metadata?.youtube_url)\n}\nexport const scoreYoutubeUrl = (youtube_url: unknown): ScaledScore => {\n if (youtube_url === undefined || youtube_url === null) return PASS\n const score: ScaledScore = [0, 2]\n if (typeof youtube_url !== 'string' || !isValidUrl(youtube_url)) return score\n incrementTotal(score)\n if (!isSecure(youtube_url)) return score\n return incrementTotal(score)\n}\n", "import type { NftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { PassFailScoringFunction } from '@xyo-network/crypto-nft-score-model'\nimport { FAIL, PASS } from '@xyo-network/crypto-nft-score-model'\n\nexport const scoreSupply: PassFailScoringFunction<NftInfoFields> = (nft: NftInfoFields) => {\n if (!nft.supply) return FAIL\n if (typeof nft.supply !== 'string') return FAIL\n try {\n return BigInt(nft.tokenId) >= 0n && BigInt(nft.tokenId) < 2n ** 256n ? PASS : FAIL\n } catch {\n return FAIL\n }\n}\n", "import type { NftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { PassFailScoringFunction } from '@xyo-network/crypto-nft-score-model'\nimport { FAIL, PASS } from '@xyo-network/crypto-nft-score-model'\n\n/**\n * Callers SHALL NOT assume that ID numbers have any specific pattern to them, and\n * MUST treat the ID as a \"black box\"\n * @param nft\n * @returns\n */\nexport const scoreTokenId: PassFailScoringFunction<NftInfoFields> = (nft: NftInfoFields) => {\n if (!nft.tokenId) return FAIL\n if (typeof nft.tokenId !== 'string') return FAIL\n try {\n return BigInt(nft.tokenId) >= 0n && BigInt(nft.tokenId) < 2n ** 256n ? PASS : FAIL\n } catch {\n return FAIL\n }\n}\n", "import type { NftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { PassFailScoringFunction } from '@xyo-network/crypto-nft-score-model'\nimport { FAIL, PASS } from '@xyo-network/crypto-nft-score-model'\n\nexport const scoreType: PassFailScoringFunction<NftInfoFields> = (nft: NftInfoFields) => {\n if ((nft.types?.length ?? 0) <= 0) return FAIL\n if (!Array.isArray(nft.types)) return FAIL\n const typesUpper = new Set(nft.types.map(t => t?.toUpperCase()))\n if (!typesUpper.has('ERC721') && !typesUpper.has('ERC1155')) return FAIL\n return PASS\n}\n", "import {\n evaluateNftAttributes,\n scoreContractAddress,\n scoreNftAnimationUrl,\n scoreNftBackgroundColor,\n scoreNftDescription,\n scoreNftExternalUrl,\n scoreNftImage,\n scoreNftImageData,\n scoreNftName,\n scoreNftYoutubeUrl,\n scoreSupply,\n scoreTokenId,\n scoreType,\n} from './scoring/index.ts'\n\nconst attributesScoringCriteria = { Attributes: { score: evaluateNftAttributes, weight: 1 } }\n\nconst metadataScoringCriteria = {\n 'Animation URL': { score: scoreNftAnimationUrl, weight: 1 },\n 'Background Color': { score: scoreNftBackgroundColor, weight: 1 },\n 'Description': { score: scoreNftDescription, weight: 1 },\n 'External Url': { score: scoreNftExternalUrl, weight: 1 },\n 'Image': { score: scoreNftImage, weight: 1 },\n 'Image Data': { score: scoreNftImageData, weight: 1 },\n 'Name': { score: scoreNftName, weight: 1 },\n 'YouTube URL': { score: scoreNftYoutubeUrl, weight: 1 },\n ...attributesScoringCriteria,\n}\n\nexport const scoringCriteria = {\n 'Contract Address': { score: scoreContractAddress, weight: 1 },\n 'Supply': { score: scoreSupply, weight: 1 },\n 'Token Id': { score: scoreTokenId, weight: 1 },\n 'Type': { score: scoreType, weight: 1 },\n ...metadataScoringCriteria,\n}\n", "import type { NftInfoFields } from '@xyo-network/crypto-nft-payload-plugin'\nimport type { Score } from '@xyo-network/crypto-nft-score-model'\n\nimport { scoringCriteria } from './criteria/index.ts'\n\nexport type ScoringCriteriaKey = keyof typeof scoringCriteria\n\nexport type NftAnalysis = Record<ScoringCriteriaKey, Score>\n\nexport const analyzeNft = async (\n /**\n * The NFT to evaluate\n */\n nft: NftInfoFields,\n): Promise<NftAnalysis> => {\n const result = Object.fromEntries(\n await Promise.all(\n Object.entries(scoringCriteria).map(async ([key, { score, weight }]) => {\n const rawScore = await score(nft)\n const weighted = rawScore.map(v => v * weight) as Score\n return [key, weighted] as const\n }),\n ),\n ) as NftAnalysis\n return result\n}\n", "import { NftSchema } from '@xyo-network/crypto-nft-payload-plugin'\nimport { createPayloadSetDivinerPlugin, PayloadSetSchema } from '@xyo-network/sdk-js'\n\nimport { NftScoreDiviner } from './Diviner.ts'\n\nexport const NftScoreDivinerPlugin = () =>\n createPayloadSetDivinerPlugin<NftScoreDiviner>(\n { required: { [NftSchema]: 1 }, schema: PayloadSetSchema },\n {\n diviner: async (params) => {\n const result = await NftScoreDiviner.create(params)\n return result\n },\n },\n )\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["PASS", "PASS", "incrementPossible", "incrementTotal", "incrementTotalAndPossible", "incrementPossible", "incrementTotal", "incrementTotalAndPossible", "PASS", "incrementTotal", "incrementTotal", "incrementTotal", "incrementTotal", "PASS", "PASS", "incrementTotal", "PASS", "incrementTotal", "incrementTotal", "PASS", "PASS", "incrementTotal", "FAIL", "PASS", "FAIL", "PASS", "FAIL", "PASS"]
|
|
7
7
|
}
|
package/dist/neutral/lib/rating/criteria/scoring/metadata/attributes/evaluateAttributes.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import type { NftInfoFields,
|
|
1
|
+
import type { NftInfoFields, OpenSeaNftInfoFields } from '@xyo-network/crypto-nft-payload-plugin';
|
|
2
2
|
import type { ScaledScore } from '@xyo-network/crypto-nft-score-model';
|
|
3
3
|
export declare const evaluateNftAttributes: (nft: NftInfoFields | OpenSeaNftInfoFields) => ScaledScore;
|
|
4
4
|
export declare const evaluateAttributes: (attributes: unknown) => ScaledScore;
|
|
5
|
-
export declare const evaluateAttribute: (attribute:
|
|
5
|
+
export declare const evaluateAttribute: (attribute: unknown) => ScaledScore;
|
|
6
6
|
//# sourceMappingURL=evaluateAttributes.d.ts.map
|
package/dist/neutral/lib/rating/criteria/scoring/metadata/attributes/evaluateAttributes.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"evaluateAttributes.d.ts","sourceRoot":"","sources":["../../../../../../../../src/lib/rating/criteria/scoring/metadata/attributes/evaluateAttributes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"evaluateAttributes.d.ts","sourceRoot":"","sources":["../../../../../../../../src/lib/rating/criteria/scoring/metadata/attributes/evaluateAttributes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAA;AACjG,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAA;AA2BtE,eAAO,MAAM,qBAAqB,GAAI,KAAK,aAAa,GAAG,oBAAoB,KAAG,WACnC,CAAA;AAE/C,eAAO,MAAM,kBAAkB,GAAI,YAAY,OAAO,KAAG,WAQxD,CAAA;AAED,eAAO,MAAM,iBAAiB,GAAI,WAAW,OAAO,KAAG,WAsBtD,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"image.d.ts","sourceRoot":"","sources":["../../../../../../../src/lib/rating/criteria/scoring/metadata/image.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAA;AACjG,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAA;AAStE,eAAO,MAAM,aAAa,GAAI,KAAK,aAAa,GAAG,oBAAoB,KAAG,
|
|
1
|
+
{"version":3,"file":"image.d.ts","sourceRoot":"","sources":["../../../../../../../src/lib/rating/criteria/scoring/metadata/image.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAA;AACjG,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAA;AAStE,eAAO,MAAM,aAAa,GAAI,KAAK,aAAa,GAAG,oBAAoB,KAAG,WASzE,CAAA;AAED,eAAO,MAAM,UAAU,GAAI,OAAO,OAAO,KAAG,WAS3C,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"imageData.d.ts","sourceRoot":"","sources":["../../../../../../../src/lib/rating/criteria/scoring/metadata/imageData.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAA;AACjG,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAA;AAoBtE,eAAO,MAAM,iBAAiB,GAAI,KAAK,aAAa,GAAG,oBAAoB,KAAG,
|
|
1
|
+
{"version":3,"file":"imageData.d.ts","sourceRoot":"","sources":["../../../../../../../src/lib/rating/criteria/scoring/metadata/imageData.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAA;AACjG,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAA;AAoBtE,eAAO,MAAM,iBAAiB,GAAI,KAAK,aAAa,GAAG,oBAAoB,KAAG,WAS7E,CAAA;AAED,eAAO,MAAM,cAAc,GAAI,YAAY,OAAO,KAAG,WAIpD,CAAA"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@xyo-network/crypto-nft-diviner-score-plugin",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "7.0.0",
|
|
4
4
|
"description": "Typescript/Javascript Plugins for XYO Platform",
|
|
5
5
|
"homepage": "https://xyo.network",
|
|
6
6
|
"bugs": {
|
|
@@ -31,30 +31,30 @@
|
|
|
31
31
|
"README.md"
|
|
32
32
|
],
|
|
33
33
|
"dependencies": {
|
|
34
|
-
"@xyo-network/crypto-nft-score-model": "~
|
|
35
|
-
"@xyo-network/crypto-nft-payload-plugin": "~
|
|
34
|
+
"@xyo-network/crypto-nft-score-model": "~7.0.0",
|
|
35
|
+
"@xyo-network/crypto-nft-payload-plugin": "~7.0.0"
|
|
36
36
|
},
|
|
37
37
|
"devDependencies": {
|
|
38
38
|
"@bitauth/libauth": "~3.0.0",
|
|
39
39
|
"@metamask/providers": "^22.1.1",
|
|
40
40
|
"@noble/post-quantum": "~0.6.1",
|
|
41
41
|
"@opentelemetry/api": "^1.9.1",
|
|
42
|
-
"@opentelemetry/sdk-trace-base": "^2.
|
|
42
|
+
"@opentelemetry/sdk-trace-base": "^2.8.0",
|
|
43
43
|
"@scure/base": "^2.2.0",
|
|
44
44
|
"@scure/bip39": "~2.2.0",
|
|
45
45
|
"@types/svg-parser": "~2.0.6",
|
|
46
|
-
"@xylabs/geo": "^6.1.
|
|
47
|
-
"@xylabs/sdk-js": "^6.1.
|
|
48
|
-
"@xylabs/threads": "^6.1.
|
|
49
|
-
"@xylabs/toolchain": "~8.
|
|
50
|
-
"@xylabs/tsconfig": "~8.
|
|
51
|
-
"@xylabs/vitest-extended": "^6.1.
|
|
52
|
-
"@xyo-network/sdk-js": "^
|
|
53
|
-
"@xyo-network/sdk-protocol-js": "~
|
|
46
|
+
"@xylabs/geo": "^6.1.3",
|
|
47
|
+
"@xylabs/sdk-js": "^6.1.3",
|
|
48
|
+
"@xylabs/threads": "^6.1.3",
|
|
49
|
+
"@xylabs/toolchain": "~8.2.7",
|
|
50
|
+
"@xylabs/tsconfig": "~8.2.7",
|
|
51
|
+
"@xylabs/vitest-extended": "^6.1.3",
|
|
52
|
+
"@xyo-network/sdk-js": "^7.0.0",
|
|
53
|
+
"@xyo-network/sdk-protocol-js": "~7.0",
|
|
54
54
|
"ajv": "^8.20.0",
|
|
55
55
|
"async-mutex": "^0.5.0",
|
|
56
56
|
"debug": "~4.4.3",
|
|
57
|
-
"eslint": "^10.
|
|
57
|
+
"eslint": "^10.5.0",
|
|
58
58
|
"ethers": "^6.16.0",
|
|
59
59
|
"hash-wasm": "^4.12.0",
|
|
60
60
|
"idb": "^8.0.3",
|
|
@@ -63,7 +63,7 @@
|
|
|
63
63
|
"svg-parser": "^2.0.4",
|
|
64
64
|
"typescript": "~6.0.3",
|
|
65
65
|
"vite": "^8.0.16",
|
|
66
|
-
"vitest": "^4.1.
|
|
66
|
+
"vitest": "^4.1.9",
|
|
67
67
|
"webextension-polyfill": "^0.12.0",
|
|
68
68
|
"zod": "^4.4.3"
|
|
69
69
|
},
|
|
@@ -78,8 +78,8 @@
|
|
|
78
78
|
"@xylabs/geo": "^6.0",
|
|
79
79
|
"@xylabs/sdk-js": "^6.0",
|
|
80
80
|
"@xylabs/threads": "^6.0",
|
|
81
|
-
"@xyo-network/sdk-js": "^
|
|
82
|
-
"@xyo-network/sdk-protocol-js": "^
|
|
81
|
+
"@xyo-network/sdk-js": "^7.0",
|
|
82
|
+
"@xyo-network/sdk-protocol-js": "^7.0",
|
|
83
83
|
"ajv": "^8.20",
|
|
84
84
|
"async-mutex": "^0.5",
|
|
85
85
|
"debug": "~4.4",
|