From 2129b51709eac6e057ba0fbbba4e5e571a7b2dc7 Mon Sep 17 00:00:00 2001 From: ffranr Date: Fri, 22 Sep 2023 20:07:11 +0100 Subject: [PATCH 1/2] proof: include outpoint field in locator hash --- proof/archive.go | 13 +++++++++++-- tapdb/assets_store.go | 23 +++++++++++++++++++---- tapfreighter/chain_porter.go | 10 +++++++++- 3 files changed, 39 insertions(+), 7 deletions(-) diff --git a/proof/archive.go b/proof/archive.go index 95ca9b967..9d255c8f9 100644 --- a/proof/archive.go +++ b/proof/archive.go @@ -17,6 +17,7 @@ import ( "github.com/lightninglabs/taproot-assets/asset" "github.com/lightninglabs/taproot-assets/fn" "github.com/lightningnetwork/lnd/lnrpc" + "github.com/lightningnetwork/lnd/lnwire" ) const ( @@ -64,7 +65,7 @@ type Locator struct { } // Hash returns a SHA256 hash of the bytes serialized locator. -func (l *Locator) Hash() [32]byte { +func (l *Locator) Hash() ([32]byte, error) { var buf bytes.Buffer if l.AssetID != nil { buf.Write(l.AssetID[:]) @@ -74,8 +75,16 @@ func (l *Locator) Hash() [32]byte { } buf.Write(l.ScriptKey.SerializeCompressed()) + if l.OutPoint != nil { + err := lnwire.WriteOutPoint(&buf, *l.OutPoint) + if err != nil { + return [32]byte{}, fmt.Errorf("unable to write "+ + "outpoint: %w", err) + } + } + // Hash the buffer. - return sha256.Sum256(buf.Bytes()) + return sha256.Sum256(buf.Bytes()), nil } // AnnotatedProof an annotated proof contains the raw proof blob along with a diff --git a/tapdb/assets_store.go b/tapdb/assets_store.go index 3e7c2931d..400377aff 100644 --- a/tapdb/assets_store.go +++ b/tapdb/assets_store.go @@ -2347,8 +2347,13 @@ func (a *AssetStore) StoreProofDeliveryAttempt(ctx context.Context, return a.db.ExecTx(ctx, &writeTxOpts, func(q ActiveAssetsStore) error { // Log proof delivery attempt and timestamp using the current // time. - proofLocatorHash := locator.Hash() - err := q.InsertReceiverProofTransferAttempt( + proofLocatorHash, err := locator.Hash() + if err != nil { + return fmt.Errorf("unable to hash proof locator: %w", + err) + } + + err = q.InsertReceiverProofTransferAttempt( ctx, InsertRecvProofTxAttemptParams{ ProofLocatorHash: proofLocatorHash[:], TimeUnix: a.clock.Now().UTC(), @@ -2375,7 +2380,12 @@ func (a *AssetStore) QueryProofDeliveryLog(ctx context.Context, readOpts := NewAssetStoreReadTx() err = a.db.ExecTx(ctx, &readOpts, func(q ActiveAssetsStore) error { - proofLocatorHash := locator.Hash() + proofLocatorHash, err := locator.Hash() + if err != nil { + return fmt.Errorf("unable to hash proof locator: %w", + err) + } + timestamps, err = q.QueryReceiverProofTransferAttempt( ctx, proofLocatorHash[:], ) @@ -2624,7 +2634,12 @@ func (a *AssetStore) reAnchorPassiveAssets(ctx context.Context, AssetID: &assetID, ScriptKey: *scriptKey, } - proofFile := proofFiles[locator.Hash()] + locatorHash, err := locator.Hash() + if err != nil { + return fmt.Errorf("failed to hash locator: %w", err) + } + + proofFile := proofFiles[locatorHash] if proofFile == nil { return fmt.Errorf("failed to find proof file for " + "passive asset") diff --git a/tapfreighter/chain_porter.go b/tapfreighter/chain_porter.go index c9c4d87eb..df3a416c1 100644 --- a/tapfreighter/chain_porter.go +++ b/tapfreighter/chain_porter.go @@ -695,7 +695,15 @@ func (p *ChainPorter) transferReceiverProof(pkg *sendPackage) error { return fmt.Errorf("error fetching passive asset "+ "proof file: %w", err) } - passiveAssetProofFiles[proofLocator.Hash()] = proofFileBlob + + // Hash proof locator. + hash, err := proofLocator.Hash() + if err != nil { + return fmt.Errorf("error hashing proof locator: %w", + err) + } + + passiveAssetProofFiles[hash] = proofFileBlob } // At this point we have the confirmation signal, so we can mark the From 30b333d89ff02a8356a11ce8264cdaeeeb227b88 Mon Sep 17 00:00:00 2001 From: ffranr Date: Fri, 22 Sep 2023 20:09:48 +0100 Subject: [PATCH 2/2] tapfreighter: populate outpoint in outbound proof locator This change ensures that the locator contains different values between two different send events which re-use the same Taproot Asset address. --- tapfreighter/chain_porter.go | 1 + 1 file changed, 1 insertion(+) diff --git a/tapfreighter/chain_porter.go b/tapfreighter/chain_porter.go index df3a416c1..5d47e9c7d 100644 --- a/tapfreighter/chain_porter.go +++ b/tapfreighter/chain_porter.go @@ -451,6 +451,7 @@ func (p *ChainPorter) storeProofs(sendPkg *sendPackage) error { outputProofLocator := proof.Locator{ AssetID: &firstInput.ID, ScriptKey: *out.ScriptKey.PubKey, + OutPoint: &firstInput.OutPoint, } outputProof := &proof.AnnotatedProof{ Locator: outputProofLocator,