From 88f3bf6b3041e6f24f8b1cbcee6d17de4d6151ec Mon Sep 17 00:00:00 2001 From: Tomasz Slabon Date: Tue, 11 Jun 2024 11:56:10 +0200 Subject: [PATCH] Simplified wallet archiving --- pkg/tbtc/node.go | 59 +++++++++++++----------------------------------- 1 file changed, 16 insertions(+), 43 deletions(-) diff --git a/pkg/tbtc/node.go b/pkg/tbtc/node.go index 51df1ccfbe..6ad13f7aa2 100644 --- a/pkg/tbtc/node.go +++ b/pkg/tbtc/node.go @@ -1097,59 +1097,32 @@ func processCoordinationResult(node *node, result *coordinationResult) { // archiveClosedWallets archives closed or terminated wallets. func (n *node) archiveClosedWallets() error { - getClosedWallets := func(walletPublicKeyHashes [][20]byte) ( - closedWallets [][20]byte, - ) { - for _, walletPublicKeyHash := range walletPublicKeyHashes { - walletChainData, err := n.chain.GetWallet(walletPublicKeyHash) - if err != nil { - // Continue if there was an error getting wallet data. Try to - // get as many closed wallets as possible. - logger.Errorf( - "could not get wallet data for wallet [0x%x]: [%v]", - walletPublicKeyHash, - err, - ) - continue - } - - if walletChainData.State == StateClosed || - walletChainData.State == StateTerminated { - closedWallets = append(closedWallets, walletPublicKeyHash) - } - } - - return - } - // Get all the wallets controlled by the node. walletPublicKeys := n.walletRegistry.getWalletsPublicKeys() - walletPublicKeyHashes := [][20]byte{} for _, walletPublicKey := range walletPublicKeys { - walletPublicKeyHashes = append( - walletPublicKeyHashes, - bitcoin.PublicKeyHash(walletPublicKey), - ) - } - - // Find the wallets that are closed. - closedWallets := getClosedWallets(walletPublicKeyHashes) - if len(closedWallets) == 0 { - logger.Infof("there are no closed wallets to archive") - return nil - } + walletPublicKeyHash := bitcoin.PublicKeyHash(walletPublicKey) - // Archive the closed wallets. - for _, walletPublicKeyHash := range closedWallets { - err := n.walletRegistry.archiveWallet(walletPublicKeyHash) + walletChainData, err := n.chain.GetWallet(walletPublicKeyHash) if err != nil { return fmt.Errorf( - "could not archive wallet with public key hash [0x%x]: [%v]", + "could not get wallet data for wallet [0x%x]: [%v]", walletPublicKeyHash, err, ) - } else { + } + + if walletChainData.State == StateClosed || + walletChainData.State == StateTerminated { + err := n.walletRegistry.archiveWallet(walletPublicKeyHash) + if err != nil { + return fmt.Errorf( + "could not archive wallet with public key hash [0x%x]: [%v]", + walletPublicKeyHash, + err, + ) + } + logger.Infof( "successfully archived wallet with public key hash [0x%x]", walletPublicKeyHash,