From 6ce1292bfacb95d8cc6fe96d2a9f1be189c2d628 Mon Sep 17 00:00:00 2001 From: SondreB Date: Tue, 10 Dec 2024 19:13:33 +0100 Subject: [PATCH 1/4] Update to latest NBitcoin - This needs to be properly verified. There has been breaking changes in NBitcoin. --- src/Angor.Test/Angor.Test.csproj | 2 +- src/Angor/Client/Angor.Client.csproj | 2 +- src/Angor/Shared/Angor.Shared.csproj | 2 +- .../Shared/ProtocolNew/FounderTransactionActions.cs | 10 +++++++--- .../Shared/ProtocolNew/InvestorTransactionActions.cs | 8 ++++++-- .../Shared/ProtocolNew/Scripts/TaprootScriptBuilder.cs | 6 ++---- .../TransactionBuilders/SpendingTransactionBuilder.cs | 2 +- 7 files changed, 19 insertions(+), 13 deletions(-) diff --git a/src/Angor.Test/Angor.Test.csproj b/src/Angor.Test/Angor.Test.csproj index c6a9c380..02195e48 100644 --- a/src/Angor.Test/Angor.Test.csproj +++ b/src/Angor.Test/Angor.Test.csproj @@ -22,7 +22,7 @@ - + runtime; build; native; contentfiles; analyzers; buildtransitive diff --git a/src/Angor/Client/Angor.Client.csproj b/src/Angor/Client/Angor.Client.csproj index fa6ed8c1..3497b235 100644 --- a/src/Angor/Client/Angor.Client.csproj +++ b/src/Angor/Client/Angor.Client.csproj @@ -11,7 +11,7 @@ - + diff --git a/src/Angor/Shared/Angor.Shared.csproj b/src/Angor/Shared/Angor.Shared.csproj index 59b5ccde..1f948dbd 100644 --- a/src/Angor/Shared/Angor.Shared.csproj +++ b/src/Angor/Shared/Angor.Shared.csproj @@ -12,7 +12,7 @@ - + diff --git a/src/Angor/Shared/ProtocolNew/FounderTransactionActions.cs b/src/Angor/Shared/ProtocolNew/FounderTransactionActions.cs index 25e63d92..0bf7c039 100644 --- a/src/Angor/Shared/ProtocolNew/FounderTransactionActions.cs +++ b/src/Angor/Shared/ProtocolNew/FounderTransactionActions.cs @@ -62,7 +62,9 @@ public SignatureInfo SignInvestorRecoveryTransactions(ProjectInfo projectInfo, s { var scriptStages = _investmentScriptBuilder.BuildProjectScriptsForStage(projectInfo, investorKey, stageIndex, secretHash); - var execData = new TaprootExecutionData(stageIndex, new NBitcoin.Script(scriptStages.Recover.ToBytes()).TaprootV1LeafHash) { SigHash = sigHash }; + var tapScript = new NBitcoin.Script(scriptStages.Recover.ToBytes()).ToTapScript(TapLeafVersion.C0); + + var execData = new TaprootExecutionData(stageIndex, tapScript.LeafHash) { SigHash = sigHash }; var hash = nbitcoinRecoveryTransaction.GetSignatureHashTaproot(outputs, execData); var sig = key.SignTaprootKeySpend(hash, sigHash).ToString(); @@ -123,8 +125,10 @@ public TransactionInfo SpendFounderStage(ProjectInfo projectInfo, IEnumerable _.Recover); - var execData = new TaprootExecutionData(stageIndex, new NBitcoin.Script(scriptStages.Recover.ToBytes()).TaprootV1LeafHash) { SigHash = sigHash }; + var tapScript = new NBitcoin.Script(scriptStages.Recover.ToBytes()).ToTapScript(TapLeafVersion.C0); + + var execData = new TaprootExecutionData(stageIndex, tapScript.LeafHash) { SigHash = sigHash }; var hash = nbitcoinRecoveryTransaction.GetSignatureHashTaproot(outputs, execData); _logger.LogInformation($"project={projectInfo.ProjectIdentifier}; investor-pubkey={key.PubKey.ToHex()}; stage={stageIndex}; hash={hash}"); @@ -290,7 +292,9 @@ public bool CheckInvestorRecoverySignatures(ProjectInfo projectInfo, Transaction { var scriptStages = _investmentScriptBuilder.BuildProjectScriptsForStage(projectInfo, investorKey, stageIndex, secretHash); - var execData = new TaprootExecutionData(stageIndex, new NBitcoin.Script(scriptStages.Recover.ToBytes()).TaprootV1LeafHash) { SigHash = sigHash }; + var tapScript = new NBitcoin.Script(scriptStages.Recover.ToBytes()).ToTapScript(TapLeafVersion.C0); + + var execData = new TaprootExecutionData(stageIndex, tapScript.LeafHash) { SigHash = sigHash }; var hash = nBitcoinRecoveryTransaction.GetSignatureHashTaproot(outputs, execData); var sig = founderSignatures.Signatures.First(f => f.StageIndex == stageIndex).Signature; diff --git a/src/Angor/Shared/ProtocolNew/Scripts/TaprootScriptBuilder.cs b/src/Angor/Shared/ProtocolNew/Scripts/TaprootScriptBuilder.cs index 4365cf29..979216d9 100644 --- a/src/Angor/Shared/ProtocolNew/Scripts/TaprootScriptBuilder.cs +++ b/src/Angor/Shared/ProtocolNew/Scripts/TaprootScriptBuilder.cs @@ -25,8 +25,7 @@ public Script CreateControlBlock(ProjectScripts scripts, Expression Date: Tue, 10 Dec 2024 19:18:25 +0100 Subject: [PATCH 2/4] Final fix for main code --- .../Shared/ProtocolNew/Scripts/TaprootScriptBuilder.cs | 7 ++++++- src/Angor/Shared/ProtocolNew/SeederTransactionActions.cs | 4 +++- 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/src/Angor/Shared/ProtocolNew/Scripts/TaprootScriptBuilder.cs b/src/Angor/Shared/ProtocolNew/Scripts/TaprootScriptBuilder.cs index 979216d9..a820c479 100644 --- a/src/Angor/Shared/ProtocolNew/Scripts/TaprootScriptBuilder.cs +++ b/src/Angor/Shared/ProtocolNew/Scripts/TaprootScriptBuilder.cs @@ -89,7 +89,12 @@ private static TaprootSpendInfo BuildTaprootSpendInfo(ProjectScripts scripts) var scriptWeights = BuildTaprootScripts(scripts); - var treeInfo = TaprootSpendInfo.WithHuffmanTree(taprootKey, scriptWeights.ToArray()); + // Transform the scripts to TapScript format + var tapScriptWeights = scriptWeights + .Select(sw => (sw.Item1, sw.Item2.ToTapScript(TapLeafVersion.C0))) + .ToList(); + + var treeInfo = TaprootSpendInfo.WithHuffmanTree(taprootKey, tapScriptWeights.ToArray()); return treeInfo; } diff --git a/src/Angor/Shared/ProtocolNew/SeederTransactionActions.cs b/src/Angor/Shared/ProtocolNew/SeederTransactionActions.cs index 54854f01..63080df8 100644 --- a/src/Angor/Shared/ProtocolNew/SeederTransactionActions.cs +++ b/src/Angor/Shared/ProtocolNew/SeederTransactionActions.cs @@ -82,7 +82,9 @@ public Transaction AddSignaturesToRecoverSeederFundsTransaction(ProjectInfo proj var controlBlock = _taprootScriptBuilder.CreateControlBlock(projectScripts, _ => _.Recover); - var execData = new TaprootExecutionData(stageIndex, new NBitcoin.Script(projectScripts.Recover.ToBytes()).TaprootV1LeafHash) { SigHash = sigHash }; + var tapScript = new NBitcoin.Script(projectScripts.Recover.ToBytes()).ToTapScript(TapLeafVersion.C0); + + var execData = new TaprootExecutionData(stageIndex, tapScript.LeafHash) { SigHash = sigHash }; var hash = nbitcoinRecoveryTransaction.GetSignatureHashTaproot(outputs, execData); _logger.LogInformation($"project={projectInfo.ProjectIdentifier}; seeder-pubkey={key.PubKey.ToHex()}; stage={stageIndex}; hash={hash}"); From 3f8e26088c7efb8ea944883491ee5e2c3fda9766 Mon Sep 17 00:00:00 2001 From: SondreB Date: Tue, 10 Dec 2024 19:22:12 +0100 Subject: [PATCH 3/4] Fix all unit tests --- src/Angor.Test/DataBuilders/AngorScripts.cs | 13 ++++++++----- src/Angor.Test/DataBuilders/InvestmentOperations.cs | 10 +++++----- 2 files changed, 13 insertions(+), 10 deletions(-) diff --git a/src/Angor.Test/DataBuilders/AngorScripts.cs b/src/Angor.Test/DataBuilders/AngorScripts.cs index 98c9b6fa..7df1679e 100644 --- a/src/Angor.Test/DataBuilders/AngorScripts.cs +++ b/src/Angor.Test/DataBuilders/AngorScripts.cs @@ -27,8 +27,7 @@ public static Script CreateControlBlock(ProjectScripts scripts, Expression (sw.Item1, sw.Item2.ToTapScript(TapLeafVersion.C0))) + .ToList(); + + var treeInfo = TaprootSpendInfo.WithHuffmanTree(taprootKey, tapScriptWeights.ToArray()); return treeInfo; } diff --git a/src/Angor.Test/DataBuilders/InvestmentOperations.cs b/src/Angor.Test/DataBuilders/InvestmentOperations.cs index c94f2b1c..3204869d 100644 --- a/src/Angor.Test/DataBuilders/InvestmentOperations.cs +++ b/src/Angor.Test/DataBuilders/InvestmentOperations.cs @@ -204,7 +204,7 @@ public Transaction SpendFounderStage(Network network, FounderContext context, in var allSpendingOutputs = signingContext.Select(s => s.spendingOutput.TxOut).ToArray(); var trxData = spender.PrecomputeTransactionData(allSpendingOutputs); - var execData = new TaprootExecutionData(inputIndex, scriptToExecute.TaprootV1LeafHash) { SigHash = sighash }; + var execData = new TaprootExecutionData(inputIndex, scriptToExecute.ToTapScript(TapLeafVersion.C0).LeafHash) { SigHash = sighash }; var hash = spender.GetSignatureHashTaproot(trxData, execData); var key = new Key(Encoders.Hex.DecodeData(founderPrivateKey)); @@ -287,7 +287,7 @@ public List FounderSignInvestorRecoveryTransactions(InvestorContext cont var hash = stageTransaction.GetSignatureHashTaproot(new[] { investmentTransaction.Outputs[i+2] }, new TaprootExecutionData(0, - new NBitcoin.Script(scriptStages.Recover.ToBytes()).TaprootV1LeafHash) + new NBitcoin.Script(scriptStages.Recover.ToBytes()).ToTapScript(TapLeafVersion.C0).LeafHash) { SigHash = sigHash }); @@ -329,7 +329,7 @@ public void AddWitScriptToInvestorRecoveryTransactions(InvestorContext context, var hash = stageTransaction.GetSignatureHashTaproot(new[] { investmentTransaction.Outputs[index + 2] }, new TaprootExecutionData(0, - new NBitcoin.Script(projectScripts.Recover.ToBytes()).TaprootV1LeafHash) + new NBitcoin.Script(projectScripts.Recover.ToBytes()).ToTapScript(TapLeafVersion.C0).LeafHash) { SigHash = sigHash }); var investorSignature = key.SignTaprootKeySpend(hash, sigHash); @@ -446,7 +446,7 @@ public Transaction RecoverEndOfProjectFunds(Network network, InvestorContext con var allSpendingOutputs = signingContext.Select(s => s.spendingOutput.TxOut).ToArray(); var trxData = spender.PrecomputeTransactionData(allSpendingOutputs); - var execData = new TaprootExecutionData(inputIndex, scriptToExecute.TaprootV1LeafHash) { SigHash = sighash }; + var execData = new TaprootExecutionData(inputIndex, scriptToExecute.ToTapScript(TapLeafVersion.C0).LeafHash) { SigHash = sighash }; var hash = spender.GetSignatureHashTaproot(trxData, execData); var key = new Key(Encoders.Hex.DecodeData(investorPrivateKey)); @@ -566,7 +566,7 @@ public Transaction RecoverFundsNoPenalty(Network network, InvestorContext contex var allSpendingOutputs = signingContext.Select(s => s.spendingOutput.TxOut).ToArray(); var trxData = spender.PrecomputeTransactionData(allSpendingOutputs); - var execData = new TaprootExecutionData(inputIndex, scriptToExecute.TaprootV1LeafHash) { SigHash = sighash }; + var execData = new TaprootExecutionData(inputIndex, scriptToExecute.ToTapScript(TapLeafVersion.C0).LeafHash) { SigHash = sighash }; var hash = spender.GetSignatureHashTaproot(trxData, execData); var key = new Key(Encoders.Hex.DecodeData(investorPrivateKey)); From 4e43c3cd08f1b0632138aeb43ebaecb65dd06c8d Mon Sep 17 00:00:00 2001 From: SondreB Date: Tue, 10 Dec 2024 19:27:39 +0100 Subject: [PATCH 4/4] Change the configuration to Release again after fixing NBitcoin. --- .github/workflows/build.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 500b9239..55170988 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -47,13 +47,13 @@ jobs: shell: bash - name: Publish - run: dotnet publish -c Debug -r ${{matrix.runtime}} /p:Version=${{ env.VERSION }}.${{ github.run_number }} -v m -o publish ${{env.PROJECT_PATH}} + run: dotnet publish -c Release -r ${{matrix.runtime}} /p:Version=${{ env.VERSION }}.${{ github.run_number }} -v m -o publish ${{env.PROJECT_PATH}} env: matrix.runtime: ${{ matrix.os == 'windows-latest' && 'win-x64' || matrix.os == 'ubuntu-latest' && 'linux-x64' || 'osx-x64' }} - name: Run Tests continue-on-error: true - run: dotnet test -c Debug -r ${{matrix.runtime}} --verbosity normal ${{env.SOLUTION_PATH}} + run: dotnet test -c Release -r ${{matrix.runtime}} --verbosity normal ${{env.SOLUTION_PATH}} env: matrix.runtime: ${{ matrix.os == 'windows-latest' && 'win-x64' || matrix.os == 'ubuntu-latest' && 'linux-x64' || 'osx-x64' }}