mirror of
https://github.com/Instadapp/trustwallet-assets.git
synced 2024-07-29 22:37:31 +00:00
ec1fe7f6ee
* Make non-mandatory action interface elements optional. * Remove one unused import * Scripts main renamed to entrypoint. * Script common rename to generic * Move generic scripts from action to generic. * Move chain-specific scripts to blockchain. Co-authored-by: Catenocrypt <catenocrypt@users.noreply.github.com>
101 lines
4.2 KiB
TypeScript
101 lines
4.2 KiB
TypeScript
import { stakingChains } from "../generic/blockchains";
|
|
import {
|
|
getChainValidatorsListPath,
|
|
getChainValidatorAssetLogoPath,
|
|
getChainValidatorsAssets
|
|
} from "../generic/repo-structure";
|
|
import { isPathExistsSync } from "../generic/filesystem";
|
|
import { formatSortJsonFile, readJsonFile } from "../generic/json";
|
|
import { ActionInterface, CheckStepInterface } from "../generic/interface";
|
|
import { isValidJSON } from "../generic/json";
|
|
import { ValidatorModel } from "../generic/validator-models";
|
|
import { isLogoOK } from "../generic/image";
|
|
import * as bluebird from "bluebird";
|
|
|
|
function formatValidators() {
|
|
stakingChains.forEach(chain => {
|
|
const validatorsPath = getChainValidatorsListPath(chain);
|
|
formatSortJsonFile(validatorsPath);
|
|
})
|
|
}
|
|
|
|
function getChainValidatorsList(chain: string): ValidatorModel[] {
|
|
return readJsonFile(getChainValidatorsListPath(chain)) as ValidatorModel[];
|
|
}
|
|
|
|
function isValidatorHasAllKeys(val: ValidatorModel): boolean {
|
|
return typeof val.id === "string"
|
|
&& typeof val.name === "string"
|
|
&& typeof val.description === "string"
|
|
&& typeof val.website === "string";
|
|
}
|
|
|
|
export class Validators implements ActionInterface {
|
|
getName(): string { return "Validators"; }
|
|
|
|
getSanityChecks(): CheckStepInterface[] {
|
|
const steps: CheckStepInterface[] = [
|
|
{
|
|
getName: () => { return "Make sure tests added for new staking chain"},
|
|
check: async (): Promise<[string[], string[]]> => {
|
|
if (stakingChains.length != 8) {
|
|
return [[`Wrong number of staking chains ${stakingChains.length}`], []];
|
|
}
|
|
return [[], []];
|
|
}
|
|
},
|
|
];
|
|
stakingChains.forEach(chain => {
|
|
steps.push(
|
|
{
|
|
getName: () => { return `Make sure chain ${chain} has valid list file, has logo`},
|
|
check: async (): Promise<[string[], string[]]> => {
|
|
const validatorsListPath = getChainValidatorsListPath(chain);
|
|
if (!isValidJSON(validatorsListPath)) {
|
|
return [[`Not valid Json file at path ${validatorsListPath}`], []];
|
|
}
|
|
|
|
const errors: string[] = [];
|
|
const validatorsList = getChainValidatorsList(chain);
|
|
const chainValidatorsAssetsList = getChainValidatorsAssets(chain);
|
|
await bluebird.each(validatorsList, async (val: ValidatorModel) => {
|
|
if (!isValidatorHasAllKeys(val)) {
|
|
errors.push(`Some key and/or type missing for validator ${JSON.stringify(val)}`);
|
|
}
|
|
|
|
const id = val.id;
|
|
const path = getChainValidatorAssetLogoPath(chain, id);
|
|
if (!isPathExistsSync(path)) {
|
|
errors.push(`Chain ${chain} asset ${id} logo must be present at path ${path}`);
|
|
}
|
|
const [isOk, logoMsg] = await isLogoOK(path);
|
|
if (!isOk) {
|
|
errors.push(logoMsg);
|
|
}
|
|
|
|
// Make sure validator has corresponding logo
|
|
if (!(chainValidatorsAssetsList.indexOf(id) >= 0)) {
|
|
errors.push(`Expecting image asset for validator ${id} on chain ${chain}`);
|
|
}
|
|
});
|
|
|
|
// Make sure validator asset logo has corresponding info
|
|
chainValidatorsAssetsList.forEach(valAssetLogoID => {
|
|
if (validatorsList.filter(v => v.id === valAssetLogoID).length != 1) {
|
|
errors.push(`Expect validator logo ${valAssetLogoID} to have info`);
|
|
}
|
|
});
|
|
|
|
return [errors, []];
|
|
}
|
|
}
|
|
);
|
|
});
|
|
return steps;
|
|
}
|
|
|
|
async sanityFix(): Promise<void> {
|
|
formatValidators();
|
|
}
|
|
}
|