From 040c33734fd9b074a248a2d62b235c4f3791d17c Mon Sep 17 00:00:00 2001 From: Ford Date: Wed, 29 Nov 2023 10:48:40 -0800 Subject: [PATCH] service: Improve validation of operator wallet Handle case where indexer does not use an operator wallet --- .../indexer-service/src/commands/start.ts | 75 ++++++++++--------- 1 file changed, 40 insertions(+), 35 deletions(-) diff --git a/packages/indexer-service/src/commands/start.ts b/packages/indexer-service/src/commands/start.ts index 4d97a868f..5bb33ce97 100644 --- a/packages/indexer-service/src/commands/start.ts +++ b/packages/indexer-service/src/commands/start.ts @@ -369,49 +369,54 @@ export default { ) // Ensure the address is checksummed - const address = toAddress(wallet.address) + const operatorAddress = toAddress(wallet.address) logger = logger.child({ indexer: indexerAddress.toString(), - operator: address.toString(), + operator: operatorAddress.toString(), }) + logger.info('Validating operator wallet is approved to take actions for indexer') // Validate the operator wallet matches the operator set for the indexer - const isOperator = await pRetry( - async () => - contracts!.staking.isOperator( - wallet.address.toString(), - indexerAddress.toString(), - ), - { - retries: 10, - maxTimeout: 10000, - onFailedAttempt: err => { - logger.warn( - `contracts.staking.isOperator(${wallet.address.toString()}, ${indexerAddress.toString()}) failed`, - { - attempt: err.attemptNumber, - retriesLeft: err.retriesLeft, - err: err.message, - }, - ) - }, - } as pRetry.Options, - ) - - if (isOperator == false) { - logger.error( - 'Operator wallet is not allowed for indexer, please see attached debug suggestions', + if (indexerAddress === operatorAddress) { + logger.info(`Indexer and operator are identical, operator status granted`) + } else { + const isOperator = await pRetry( + async () => + contracts!.staking.isOperator( + wallet.address.toString(), + indexerAddress.toString(), + ), { - debugSuggestion1: 'verify that operator wallet is set for indexer account', - debugSuggestion2: - 'verify that service and agent are both using correct operator wallet mnemonic', - }, - ) - throw indexerError( - IndexerErrorCode.IE034, - `contracts.staking.isOperator returned 'False'`, + retries: 10, + maxTimeout: 10000, + onFailedAttempt: err => { + logger.warn( + `contracts.staking.isOperator(${wallet.address.toString()}, ${indexerAddress.toString()}) failed`, + { + attempt: err.attemptNumber, + retriesLeft: err.retriesLeft, + err: err.message, + }, + ) + }, + } as pRetry.Options, ) + + if (isOperator == false) { + logger.error( + 'Operator wallet is not allowed for indexer, please see attached debug suggestions', + { + debugSuggestion1: 'verify that operator wallet is set for indexer account', + debugSuggestion2: + 'verify that service and agent are both using correct operator wallet mnemonic', + }, + ) + throw indexerError( + IndexerErrorCode.IE034, + `contracts.staking.isOperator returned 'False'`, + ) + } } // Monitor indexer allocations that we may receive traffic for