diff --git a/asset/asset.go b/asset/asset.go index bc0a6363d..1aec83c07 100644 --- a/asset/asset.go +++ b/asset/asset.go @@ -1067,7 +1067,8 @@ func NewGKRCustomSubtreeRootRecord(root *chainhash.Hash) tlv.Record { // 1. It cannot be misinterpreted as a genesis asset ID leaf. // 2. It optionally includes user-defined script spending leaves. // - is the root hash of the custom tapscript subtree. -// If not specified, it defaults to a 32-byte zero-filled array. +// If not specified, it defaults to the same [OP_RETURN] that's on the left +// side. // - [OP_RETURN] is a non-spendable script leaf containing the script // `OP_RETURN`. Its presence ensures that [tweaked_custom_branch] remains // a branch node and cannot be a valid genesis asset ID leaf. @@ -1108,7 +1109,7 @@ func NewGroupKeyTapscriptRoot(genesisAssetID ID, // hash of the custom tapscript subtree. // // If a custom tapscript subtree root hash is provided, we use it. - // Otherwise, we default to an empty hash (a zero-filled byte array). + // Otherwise, we default to an empty non-spendable leaf hash as well. emptyNonSpendLeaf, err := NewNonSpendableScriptLeaf(nil) if err != nil { return GroupKeyRevealTapscript{}, err @@ -1117,7 +1118,7 @@ func NewGroupKeyTapscriptRoot(genesisAssetID ID, // Compute the tweaked custom branch hash. tweakedCustomBranchHash := TapBranchHash( emptyNonSpendLeaf.TapHash(), - customRoot.UnwrapOr(chainhash.Hash{}), + customRoot.UnwrapOr(emptyNonSpendLeaf.TapHash()), ) // Next, we'll combine the tweaked custom branch hash with the genesis