descriptor: Move filling of keys from DescriptorImpl::MakeScripts to PubkeyProvider::GetPubKey #31243

pull achow101 wants to merge 4 commits into bitcoin:master from achow101:descriptor-direct-fill changing 4 files +80 −64
  1. achow101 commented at 4:56 pm on November 7, 2024: member

    Instead of having MakeScripts infer what pubkeys need to go into the output FlatSigningProvider, have each of the PubkeyProviders that have GetPubKey called fill it directly with relevant keys and origins.

    This allows for keys and origins to be added that won’t directly appear in the output, which is necessary for musig() descriptors.

    Split from #29675

  2. DrahtBot commented at 4:56 pm on November 7, 2024: contributor

    The following sections might be updated with supplementary metadata relevant to reviewers and maintainers.

    Code Coverage & Benchmarks

    For details see: https://corecheck.dev/bitcoin/bitcoin/pulls/31243.

    Reviews

    See the guideline for information on the review process.

    Type Reviewers
    ACK theStack

    If your review is incorrectly listed, please react with 👎 to this comment and the bot will ignore it on the next update.

    Conflicts

    Reviewers, this pull request conflicts with the following ones:

    • #31590 (descriptors: Try pubkeys of both parities when retrieving the private keys for an xonly pubkey in a descriptor by achow101)
    • #31519 (refactor: Use std::span over Span by maflcko)
    • #31244 (descriptors: MuSig2 by achow101)
    • #29675 (wallet: Be able to receive and spend inputs involving MuSig2 aggregate keys by achow101)
    • #28710 (Remove the legacy wallet and BDB dependency by achow101)

    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.

  3. achow101 force-pushed on Nov 7, 2024
  4. in src/script/descriptor.cpp:215 in f50470e33c outdated
    211@@ -212,7 +212,7 @@ struct PubkeyProvider
    212     virtual bool ToNormalizedString(const SigningProvider& arg, std::string& out, const DescriptorCache* cache = nullptr) const = 0;
    213 
    214     /** Derive a private key, if private data is available in arg. */
    215-    virtual bool GetPrivKey(int pos, const SigningProvider& arg, CKey& key) const = 0;
    216+    virtual void GetPrivKey(int pos, const SigningProvider& arg, FlatSigningProvider& out) const = 0;
    


    theStack commented at 4:07 pm on November 14, 2024:
    in commit f50470e33c1bb51531f3fa08f6d29c54df304d6b: nit: could also update the comment here, e.g. add “… and put it into the passed signing provider.”

    achow101 commented at 5:03 pm on November 19, 2024:
    Done
  5. in src/script/descriptor.cpp:713 in db270fa2a3 outdated
    711+        FlatSigningProvider subprovider;
    712+        std::vector<CPubKey> pubkeys;
    713+        pubkeys.reserve(m_pubkey_args.size());
    714 
    715-        // Construct temporary data in `entries`, `subscripts`, and `subprovider` to avoid producing output in case of failure.
    716+        // Construct temporary data in `pks`, `subscripts`, and `subprovider` to avoid producing output in case of failure.
    


    theStack commented at 2:46 pm on November 15, 2024:

    comment nit

    0        // Construct temporary data in `pubkeys`, `subscripts`, and `subprovider` to avoid producing output in case of failure.
    

    achow101 commented at 5:03 pm on November 19, 2024:
    Done
  6. in src/script/descriptor.h:117 in d1be907045 outdated
    110@@ -111,6 +111,9 @@ struct Descriptor {
    111     /** Whether this descriptor will return one scriptPubKey or multiple (aka is or is not combo) */
    112     virtual bool IsSingleType() const = 0;
    113 
    114+    /** Whether this descriptor only produces single key scripts (i.e. pk(), pkh(), wpkh(), sh() and wsh() nested of those, and combo() */
    115+    virtual bool IsSingleKey() const = 0;
    


    theStack commented at 4:28 pm on November 17, 2024:
    nit: I wonder if this method will still be needed once the legacy wallet (and with that, the importmulti RPC call in particular) is gone? If not, could maybe add a TODO here to get rid of it in the future.

    achow101 commented at 5:03 pm on November 19, 2024:
    Added a TODO
  7. theStack approved
  8. theStack commented at 4:31 pm on November 17, 2024: contributor

    Code-review ACK f50470e33c1bb51531f3fa08f6d29c54df304d6b

    To my understanding, the second and fourth commits (db270fa2a33d7c88e58682ab8a219a2e70503c9e and f50470e33c1bb51531f3fa08f6d29c54df304d6b) are pure refactors, while the third one actually changes behaviour for Descriptor::Expand call-sites w.r.t. by returning more public key data than before (stored in the FlatSigningProvider& out parameter), so the first commit (d1be90704559da45e4d76171230ecb9f4a6d9cf8) is needed to avoid breaking the importmulti RPC call behaviour. Without that, the “Imported scripts with pubkeys should not have their pubkeys go into the keypool” sub-test in wallet_importmulti.py fails.

  9. wallet, rpc: Only allow keypool import from single key descriptors
    Instead of relying on implicit assumptions about whether pubkeys show up
    or now after expanding a descriptor, just explicitly allow only single
    key descriptors to import keys into a legacy wallet's keypool.
    7c614b15bc
  10. descriptors: Have GetPubKey fill origins directly
    Instead of having ExpandHelper fill in the origins in the
    FlatSigningProvider output, have GetPubKey do it by itself. This reduces
    the extra variables needed in order to track and set origins in
    ExpandHelper.
    
    Also changes GetPubKey to return a std::optional<CPubKey> rather than
    using a bool and output parameters.
    bda628af06
  11. descriptors: Move FlatSigningProvider pubkey filling to GetPubKey
    Instead of MakeScripts inconsistently filling the output
    FlatSigningProvider with the pubkeys involved, just do it in GetPubKey.
    d240deab1c
  12. descriptors: Have GetPrivKey fill keys directly
    Instead of GetPrivKey returning a key and having the caller fill the
    FlatSigningProvider, have GetPrivKey take the FlatSigningProvider and
    fill it by itself.
    
    GetPrivKey is now changed to void as the caller no longer cares whether
    it succeeds or fails.
    186bc75985
  13. achow101 force-pushed on Nov 19, 2024
  14. theStack approved
  15. theStack commented at 10:15 pm on November 19, 2024: contributor
    re-ACK 186bc75985a0afa96eba3c5bfea09e22fe3ec2c8 🗒️

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 site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me