From 991ecf914a861f1dcd7a992117a315b08305c4b7 Mon Sep 17 00:00:00 2001 From: Michal Zielenkiewicz Date: Tue, 7 Jan 2025 07:51:01 +0100 Subject: [PATCH] Set API limit when fetching data for named validators --- .changelog/1673.bugfix.md | 1 + src/oasis-nexus/api.ts | 47 ++++++++++++++++++++++----------------- 2 files changed, 27 insertions(+), 21 deletions(-) create mode 100644 .changelog/1673.bugfix.md diff --git a/.changelog/1673.bugfix.md b/.changelog/1673.bugfix.md new file mode 100644 index 000000000..2021886eb --- /dev/null +++ b/.changelog/1673.bugfix.md @@ -0,0 +1 @@ +Set API limit when fetching data for named validators diff --git a/src/oasis-nexus/api.ts b/src/oasis-nexus/api.ts index ba56aed68..ffd148acb 100644 --- a/src/oasis-nexus/api.ts +++ b/src/oasis-nexus/api.ts @@ -30,6 +30,7 @@ import { getRPCAccountBalances } from '../app/utils/getRPCAccountBalances' import { toChecksumAddress } from '@ethereumjs/util' import { fromBaseUnits } from '../app/utils/number-utils' import { getConsensusTransactionAmount, getConsensusTransactionToAddress } from '../app/utils/transaction' +import { API_MAX_TOTAL_COUNT } from '../app/config' export * from './generated/api' export type { RuntimeEvmBalance as Token } from './generated/api' @@ -1120,28 +1121,32 @@ export type ValidatorAddressNameMap = { [oasisAddress: string]: string | undefin export const useGetConsensusValidatorsAddressNameMap: typeof generated.useGetConsensusValidators< AxiosResponse > = (network, params?, options?) => { - return generated.useGetConsensusValidators(network, params, { - ...options, - query: { - staleTime: options?.query?.staleTime ?? 5 * 60 * 1000, // Defaults to 5 minutes - ...options?.query, - }, - request: { - ...options?.request, - transformResponse: [ - ...arrayify(axios.defaults.transformResponse), - (data: generated.ValidatorList, headers, status) => { - if (status !== 200) return data - const validators: ValidatorAddressNameMap = {} - data.validators.forEach(validator => { - validators[validator.entity_address] = validator.media?.name - }) - return validators - }, - ...arrayify(options?.request?.transformResponse), - ], + return generated.useGetConsensusValidators( + network, + { limit: API_MAX_TOTAL_COUNT, ...params }, + { + ...options, + query: { + staleTime: options?.query?.staleTime ?? 5 * 60 * 1000, // Defaults to 5 minutes + ...options?.query, + }, + request: { + ...options?.request, + transformResponse: [ + ...arrayify(axios.defaults.transformResponse), + (data: generated.ValidatorList, headers, status) => { + if (status !== 200) return data + const validators: ValidatorAddressNameMap = {} + data.validators.forEach(validator => { + validators[validator.entity_address] = validator.media?.name + }) + return validators + }, + ...arrayify(options?.request?.transformResponse), + ], + }, }, - }) + ) } export const useGetConsensusValidators: typeof generated.useGetConsensusValidators = (