Skip to content

Commit

Permalink
Additional instances
Browse files Browse the repository at this point in the history
  • Loading branch information
pxrl committed Oct 24, 2023
1 parent 7939670 commit cb93486
Showing 1 changed file with 15 additions and 5 deletions.
20 changes: 15 additions & 5 deletions src/utils/ProviderUtils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -72,8 +72,14 @@ class RateLimitedProvider extends ethers.providers.StaticJsonRpcProvider {

const defaultTimeout = 60 * 1000;

// @dev To avoid accidentally leaking RPC keys in log messages, resolve the RPC provider protocol and
// hostname centrally. There should be no instances of `provider.connection.url` in log messages or errors.
function getProviderOrigin(provider: ethers.providers.StaticJsonRpcProvider): string {
return getOriginFromURL(provider.connection.url);
}

function formatProviderError(provider: ethers.providers.StaticJsonRpcProvider, rawErrorText: string) {
return `Provider ${getOriginFromURL(provider.connection.url)} failed with error: ${rawErrorText}`;
return `Provider ${getProviderOrigin(provider)} failed with error: ${rawErrorText}`;
}

function createSendErrorWithMessage(message: string, sendError: any) {
Expand Down Expand Up @@ -127,6 +133,8 @@ class CacheProvider extends RateLimitedProvider {
this.maxReorgDistance = CHAIN_CACHE_FOLLOW_DISTANCE[chainId];

// Pre-compute as much of the redis key as possible.
// The full provider URL is deliberately used here, since the redis cache is considered sensitive,
// but additional caution is needed to ensure the cache prefix is not logged anywhere.
const cachePrefix = `${providerCacheNamespace},${new URL(this.connection.url).hostname},${chainId}`;
this.getBlockByNumberPrefix = `${cachePrefix}:getBlockByNumber,`;
this.getLogsCachePrefix = `${cachePrefix}:eth_getLogs,`;
Expand Down Expand Up @@ -306,7 +314,9 @@ export class RetryProvider extends ethers.providers.StaticJsonRpcProvider {
if (!results.every(isPromiseFulfilled)) {
// Format the error so that it's very clear which providers failed and succeeded.
const errorTexts = errors.map(([provider, errorText]) => formatProviderError(provider, errorText));
const successfulProviderUrls = results.filter(isPromiseFulfilled).map((result) => result.value[0].connection.url);
const successfulProviderUrls = results
.filter(isPromiseFulfilled)
.map((result) => getProviderOrigin(result.value[0]));
throw createSendErrorWithMessage(
`Not enough providers succeeded. Errors:\n${errorTexts.join("\n")}\n` +
`Successful Providers:\n${successfulProviderUrls.join("\n")}`,
Expand All @@ -324,7 +334,7 @@ export class RetryProvider extends ethers.providers.StaticJsonRpcProvider {

const throwQuorumError = () => {
const errorTexts = errors.map(([provider, errorText]) => formatProviderError(provider, errorText));
const successfulProviderUrls = values.map(([provider]) => provider.connection.url);
const successfulProviderUrls = values.map(([provider]) => getProviderOrigin(provider));
throw new Error(
"Not enough providers agreed to meet quorum.\n" +
"Providers that errored:\n" +
Expand Down Expand Up @@ -390,11 +400,11 @@ export class RetryProvider extends ethers.providers.StaticJsonRpcProvider {
const mismatchedProviders = Object.fromEntries(
[...values, ...fallbackValues]
.filter(([, result]) => !compareRpcResults(method, result, quorumResult))
.map(([provider, result]) => [provider.connection.url, result])
.map(([provider, result]) => [getProviderOrigin(provider), result])
);
const quorumProviders = [...values, ...fallbackValues]
.filter(([, result]) => compareRpcResults(method, result, quorumResult))
.map(([provider]) => provider.connection.url);
.map(([provider]) => getProviderOrigin(provider));
if (Object.keys(mismatchedProviders).length > 0 || errors.length > 0) {
logger.warn({
at: "ProviderUtils",
Expand Down

0 comments on commit cb93486

Please sign in to comment.