From 8db02f3ef5493954508aeacb4dc9a4932d24f8ba Mon Sep 17 00:00:00 2001 From: cryptoryda Date: Thu, 15 Feb 2024 12:48:50 +0000 Subject: [PATCH] Validation for Optional Fields --- src/validate/data.json.mjs | 40 ++++++++++++++++++++++++++++++-------- 1 file changed, 32 insertions(+), 8 deletions(-) diff --git a/src/validate/data.json.mjs b/src/validate/data.json.mjs index 0a5703a..04716ff 100644 --- a/src/validate/data.json.mjs +++ b/src/validate/data.json.mjs @@ -1,9 +1,17 @@ import assert from 'node:assert' import { isObject, noDuplicateStringInArray, parseURL } from './helper.mjs' import { getAddress } from 'ethers' +import winston from 'winston'; import { NETWORK_DATA } from '../chains.mjs' +// Create a logger +const logger = winston.createLogger({ + transports: [ + new winston.transports.Console(), + ], +}); + function validateGlobalKeys(dataDotJsonObject) { const GLOBAL_KEYS = [ 'name', @@ -56,23 +64,30 @@ function validateGlobalKeys(dataDotJsonObject) { } } -function validateName() {} +function validateName() { } -function validateSymbol() {} +function validateSymbol() { } function validateDecimals(decimals) { assert(decimals > 0, 'invalid decimals, must > 0') assert(decimals <= 18, 'invalid decimals, must <= 18') } -function validateTokens(tokens) { - const CHAIN_NAMES = Object.keys(NETWORK_DATA) - const keys = Object.keys(tokens) +function validateToken([_chainName, token]) { + const TOKEN_KEYS = ['address'] + const keys = Object.keys(token) // prettier-ignore { - assert(noDuplicateStringInArray(keys), `found duplicate key, valid keys are ${CHAIN_NAMES.toString()}`) - assert(keys.every((key) => CHAIN_NAMES.includes(key)), `found invalid key, valid keys are ${CHAIN_NAMES.toString()}`) + assert(noDuplicateStringInArray(keys), `found duplicate key, valid keys are ${TOKEN_KEYS.toString()}`) + assert(keys.every((key) => TOKEN_KEYS.includes(key)), `found invalid key, valid keys are ${TOKEN_KEYS.toString()}`) + } + + try { + getAddress(token.address) + } catch (error) { + logger.error(`Invalid address for token: ${token.address}`); + // You might choose to throw an error here or handle it accordingly. } } @@ -99,8 +114,17 @@ ${JSON.stringify(dataDotJsonObject, null, 2)}`) validateGlobalKeys(dataDotJsonObject) const { name, symbol, decimals, tokens } = dataDotJsonObject - // prettier-ignore + + Object.entries(tokens).forEach((token) => { + try { + validateToken(token); + } catch (error) { + logger.error(`Error validating token: ${error.message}`); + // Handle the error, maybe skip the token or log a warning, depending on your use case. + } + }); + assert.equal(tokenFolderName, symbol, 'require token symbol = token folder name') validateName(name) validateSymbol(symbol)