util, rpc: Add parameter to deriveaddresses to display address information #25366

pull w0xlt wants to merge 2 commits into bitcoin:master from w0xlt:desc_rpc changing 3 files +108 −8
  1. w0xlt commented at 11:30 pm on June 13, 2022: contributor

    This PR adds the details parameter to deriveaddresses RPC. With this option enabled, this RPC will return the private and public key and the output script for each address, as seen below.

    Motivation: I needed to retrieve the private key from an address generated by a descriptor wallet, but dumpprivkey is not available for new wallets. This change allows extracting this type of information from an address generated by a descriptor.

    If the descriptor contains xpub instead of xpriv, the private_key field will be omitted. If the descriptor is non-ranged, the index field will be omitted.

    This PR does not change the current behavior if the new parameter is not used.

    Example:

     0$ bitcoin-cli -signet deriveaddresses "tr(tprv8ZgxMBicQKsPfMzHFsP1xhYbMGowTt7PPwkfsuBDhCN7rSnCTSConREDsnroDrtNtCCxzhGvhLYVCULPDtrzTV7w1wNWMPsBz2tbX3tKFRy/86'/1'/0'/0/*)#ndy4d8qe" "[0,2]" true
     1[
     2  {
     3    "index": 0,
     4    "address": "tb1p840d3777aztc9mpa4yndtk882ja8cpqstq96399gm5atk8ekt2ws3etmlg",
     5    "output_script": "51203d5ed8fbdee89782ec3da926d5d8e754ba7c0410580ba894a8dd3abb1f365a9d",
     6    "public_key": "02557828307dcf41e15753ec4c7e1f7af149dd85f8e2a10b81bc81174f9129997b",
     7    "private_key": "cP7pg6J5tFzAf1SiPVnJs12EPUgaiVh55uNbfaRgkjAr2cEqf1bK"
     8  },
     9  {
    10    "index": 1,
    11    "address": "tb1psjvm057x7v8rv45apk5jtplw5w49r9l4wn4q6mc3urdv57wg98zqnygxsq",
    12    "output_script": "51208499b7d3c6f30e36569d0da92587eea3aa5197f574ea0d6f11e0daca79c829c4",
    13    "public_key": "02c80f11f563cd9cbf5a26f335bb363fddb7155f97c1a3d26e0f2c8132df33b7d9",
    14    "private_key": "cPCwhcnJqeVEp2APohD11ZXqVhzEnvYmB37JHfif2sAJD5fZygiQ"
    15  },
    16  {
    17    "index": 2,
    18    "address": "tb1pggz3twdfe25cczrwc7mf3p3qyrp4m8f75t4ug8r0mfw9kaen3m0sfm3t3y",
    19    "output_script": "5120420515b9a9caa98c086ec7b698862020c35d9d3ea2ebc41c6fda5c5b77338edf",
    20    "public_key": "03f8441bf1a56ba725ab58084f449ec147c21359aa59441834df5f15097e846b1f",
    21    "private_key": "cRPpFpwTZ2P4Jz7Rna7A72caVhQEGyco1R8yHY1KV2s1KdrNEdkZ"
    22  }
    23]
    
  2. Slavo77AssMiner approved
  3. DrahtBot added the label RPC/REST/ZMQ on Jun 14, 2022
  4. sipa commented at 10:00 am on June 14, 2022: member

    That seems dangerous as descriptor wallets (by default) use unhardened derivation, so leaking one derived private key is sufficient for an attacker to compute every private key. The choice to only allow exporting the xprv was deliberate, as with that, it’d be more obvious to users that what was being revealed was their entire wallet.

    Also: what does this do if multiple keys are involved?

  5. w0xlt force-pushed on Jun 14, 2022
  6. w0xlt commented at 3:46 pm on June 14, 2022: contributor

    @sipa Yes, it’s a good point. I initially considered that this might be as risky as running listdescriptors with the private parameter set to true.

    I changed the code to support multiple keys (and added functional tests for this case).

    Example:

     0./src/bitcoin-cli -signet deriveaddresses "wsh(multi(2,tprv8ZgxMBicQKsPePmENhT9N9yiSfTtDoC1f39P7nNmgEyCB6Nm4Qiv1muq4CykB9jtnQg2VitBrWh8PJU8LHzoGMHTrS2VKBSgAz7Ssjf9S3P/86'/1'/0'/0/*,tprv8ZgxMBicQKsPfMzHFsP1xhYbMGowTt7PPwkfsuBDhCN7rSnCTSConREDsnroDrtNtCCxzhGvhLYVCULPDtrzTV7w1wNWMPsBz2tbX3tKFRy/86'/1'/0'/0/*))#kjq88ke0" "0" true
     1[
     2  {
     3    "index": 0,
     4    "address": "tb1qupzqr3kdgn6zdjkemlfy5kytr42z96wsutjjylvj4qvwm2argvts62apa2",
     5    "output_script": "0020e04401c6cd44f426cad9dfd24a588b1d5422e9d0e2e5227d92a818edaba34317",
     6    "public_keys": [
     7      "02557828307dcf41e15753ec4c7e1f7af149dd85f8e2a10b81bc81174f9129997b",
     8      "03f1f8587257e595dd5a1699da22b749cb9bea5f5d0b9bccfb43f119092b1297de"
     9    ],
    10    "private_keys": [
    11      "cP7pg6J5tFzAf1SiPVnJs12EPUgaiVh55uNbfaRgkjAr2cEqf1bK",
    12      "cTDRhufTmDDw8hUGkpyY9bjX41Y4jiHYJVcZUpCeK3WJztm152hd"
    13    ]
    14  }
    15]
    
  7. achow101 commented at 6:55 pm on June 14, 2022: member
    I think the option for private keys should be separate from the option for other details. I am also hesitant about outputting private keys because of the unhardened derivation problem.
  8. DrahtBot commented at 8:33 am on June 15, 2022: contributor

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

    Conflicts

    Reviewers, this pull request conflicts with the following ones:

    • #26039 (rpc: Run type check against RPCArgs (1/2) by MarcoFalke)
    • #24162 (rpc: add require_checksum flag to deriveaddresses by kallewoof)
    • #23549 (Add scanblocks RPC call (attempt 2) by jamesob)
    • #22838 (descriptors: Be able to specify change and receiving in a single descriptor string 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.

  9. w0xlt force-pushed on Jun 15, 2022
  10. w0xlt commented at 6:45 pm on June 15, 2022: contributor

    I removed the private keys from RPC result as it is raising concerns about unhardened derivation problem. As mentioned before, my initial idea is to provide a way to get the private key (and also other information) about an address, as dumpprivkey is not available for descriptor wallets. Not sure if this PR is still useful without this field.

    I think that separating private key option from the details can result in bad UX as the user can enter a xpub and set this option as true.

     0$ bitcoin-cli -signet deriveaddresses "wsh(multi(2,tprv8ZgxMBicQKsPePmENhT9N9yiSfTtDoC1f39P7nNmgEyCB6Nm4Qiv1muq4CykB9jtnQg2VitBrWh8PJU8LHzoGMHTrS2VKBSgAz7Ssjf9S3P/0/*,tpubDBYDcH8P2PedrEN3HxWYJJJMZEdgnrqMsjeKpPNzwe7jmGwk5M3HRdSf5vudAXwrJPfUsfvUPFooKWmz79Lh111U51RNotagXiGNeJe3i6t/1/*))#szn2yxkq" "0" true
     1[
     2  {
     3    "index": 0,
     4    "address": "tb1qqsat6c82fvdy73rfzye8f7nwxcz3xny7t56azl73g95mt3tmzvgs9a8vjs",
     5    "output_script": "0020043abd60ea4b1a4f4469113274fa6e3605134c9e5d35d17fd14169b5c57b1311",
     6    "public_keys": [
     7      "0281c133371848d11ac195189bdfd32c1bbf39ebc1ee1b627897afd2ff8770e77b",
     8      "03db7c6fb51e4386137e2a320c25a8681ebdc5130a902c7abb9fb94d7358f9ca70"
     9    ]
    10  }
    11]
    
  11. luke-jr commented at 9:30 pm on June 18, 2022: member
    (Arguably derivation means these “private keys” are really just a mid-state of the signature algorithm, and the entire wallet uses a single private key)
  12. util: Add details to `deriveaddresses` RPC 544c2cce91
  13. util: add tests for `deriveaddresses` details parameter 40661512aa
  14. in src/rpc/output_script.cpp:240 in 80317cb479 outdated
    236@@ -237,12 +237,30 @@ static RPCHelpMan deriveaddresses()
    237         {
    238             {"descriptor", RPCArg::Type::STR, RPCArg::Optional::NO, "The descriptor."},
    239             {"range", RPCArg::Type::RANGE, RPCArg::Optional::OMITTED_NAMED_ARG, "If a ranged descriptor is used, this specifies the end or the range (in [begin,end] notation) to derive."},
    240+            {"details", RPCArg::Type::BOOL, RPCArg::Default{false}, "If true, the keys of each address will be shown. Private keys will be shown only if the descriptor contains xpriv."},
    


    luke-jr commented at 9:32 pm on June 18, 2022:
    Booleans should typically not be positional arguments, but instead members of an “options” Object.

    w0xlt commented at 11:45 am on June 20, 2022:
  15. w0xlt force-pushed on Jun 20, 2022
  16. w0xlt commented at 11:48 am on June 20, 2022: contributor
  17. achow101 commented at 7:34 pm on October 12, 2022: member
    This PR does not seem to have conceptual support. Please leave a comment if you would like this to be reopened.
  18. achow101 closed this on Oct 12, 2022

  19. bitcoin locked this on Oct 12, 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-15 09:12 UTC

This site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me