wallet: Use single FastRandomContext when creating a wallet tx #24560
pull MarcoFalke wants to merge 2 commits into bitcoin:master from MarcoFalke:2203-RandWallet-🗾 changing 5 files +86 −52-
MarcoFalke commented at 2:21 pm on March 14, 2022: memberPassing around a single randomness context shouldn’t come with any downsides, but documents better where randomness is used and allows the unit test to be deterministic, if they wish to be so.
-
wallet: Pass FastRandomContext& to DiscourageFeeSniping 77773b061c
-
wallet: Pass FastRandomContext& to coin selection fa7deaa046
-
MarcoFalke added the label Refactoring on Mar 14, 2022
-
MarcoFalke renamed this:
wallet: Pass FastRandomContext& to DiscourageFeeSniping
wallet: Use single FastRandomContext when creating a wallet tx
on Mar 14, 2022 -
MarcoFalke added the label Wallet on Mar 14, 2022
-
DrahtBot commented at 2:29 pm on March 14, 2022: member
The following sections might be updated with supplementary metadata relevant to reviewers and maintainers.
Conflicts
Reviewers, this pull request conflicts with the following ones:
- #24494 (wallet: generate random change target for each tx for better privacy by glozow)
- #24213 (refactor: use Span in random.*; make GetRand a template, remove GetRandInt by PastaPastaPasta)
- #24128 (wallet: BIP 326 sequence based anti-fee-snipe for taproot inputs by MarcoFalke)
- #23475 (wallet: add config to prioritize a solution that doesn’t create change in coin selection by brunoerg)
- #23076 (Pass CFeeRate and CTxMemPool in-params by reference to const by jonatack)
- #20640 (wallet, refactor: return out-params of CreateTransaction() as optional struct by theStack)
If you consider this pull request important, please also help to review the conflicting pull requests. Ideally, start with the one that should be merged first.
-
glozow commented at 4:14 pm on March 14, 2022: memberConcept ACK
-
in src/wallet/coinselection.cpp:194 in fa7deaa046
190@@ -191,16 +191,14 @@ std::optional<SelectionResult> SelectCoinsSRD(const std::vector<OutputGroup>& ut 191 return std::nullopt; 192 } 193 194-static void ApproximateBestSubset(const std::vector<OutputGroup>& groups, const CAmount& nTotalLower, const CAmount& nTargetValue, 195+static void ApproximateBestSubset(FastRandomContext& insecure_rand, const std::vector<OutputGroup>& groups, const CAmount& nTotalLower, const CAmount& nTargetValue,
promag commented at 6:28 pm on March 17, 2022:nit, any reason to be the 1st arg?
MarcoFalke commented at 6:33 pm on March 17, 2022:It can’t be the last arg, because that requires a default value, so I picked the “least-last” arg (aka first)promag commented at 6:28 pm on March 17, 2022: memberCode review ACK fa7deaa0464576a229b5a6ab13ad033c16d0dada.glozow commented at 11:56 am on March 21, 2022: memberlight code review ACK fa7deaa0464576a229b5a6ab13ad033c16d0dadaachow101 commented at 5:40 pm on March 23, 2022: memberACK fa7deaa0464576a229b5a6ab13ad033c16d0dadaachow101 merged this on Mar 23, 2022achow101 closed this on Mar 23, 2022
sidhujag referenced this in commit aa27161a51 on Mar 24, 2022MarcoFalke deleted the branch on Mar 24, 2022DrahtBot locked this on Mar 24, 2023
github-metadata-mirror
This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-21 09:12 UTC
This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-21 09:12 UTC
This site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me
More mirrored repositories can be found on mirror.b10c.me