wallet: Deprecate addwitnessaddress #12210

pull laanwj wants to merge 1 commits into bitcoin:master from laanwj:2018_01_deprecate_addwitnessaddress changing 7 files +18 −9
  1. laanwj commented at 12:22 pm on January 17, 2018: member
    Now that segwit is natively supported by the wallet, deprecate the hack addwitnessaddress.
  2. in src/wallet/rpcwallet.cpp:1288 in 092e43e14d outdated
    1284@@ -1285,7 +1285,8 @@ UniValue addwitnessaddress(const JSONRPCRequest& request)
    1285     if (request.fHelp || request.params.size() < 1 || request.params.size() > 2)
    1286     {
    1287         std::string msg = "addwitnessaddress \"address\" ( p2sh )\n"
    1288-            "\nAdd a witness address for a script (with pubkey or redeemscript known). Requires a new wallet backup.\n"
    1289+            "\nDEPRECATED: use option -addresstype=[bech32|p2sh-segwit] instead.\n"
    


    luke-jr commented at 12:23 pm on January 17, 2018:
    Wouldn’t it be better to suggest using the RPC parameters, rather than changing the config file and restarting?

    meshcollider commented at 12:26 pm on January 17, 2018:
    Yeah getnewaddress with the address_type parameter more closely resembles what this RPC was used for IMO

    laanwj commented at 12:26 pm on January 17, 2018:
    best to document both, I’ll mention that option as well.
  3. in src/wallet/rpcwallet.cpp:1289 in 092e43e14d outdated
    1284@@ -1285,7 +1285,8 @@ UniValue addwitnessaddress(const JSONRPCRequest& request)
    1285     if (request.fHelp || request.params.size() < 1 || request.params.size() > 2)
    1286     {
    1287         std::string msg = "addwitnessaddress \"address\" ( p2sh )\n"
    1288-            "\nAdd a witness address for a script (with pubkey or redeemscript known). Requires a new wallet backup.\n"
    1289+            "\nDEPRECATED: use option -addresstype=[bech32|p2sh-segwit] instead.\n"
    1290+            "Add a witness address for a script (with pubkey or redeemscript known). Requires a new wallet backup.\n"
    


    luke-jr commented at 12:23 pm on January 17, 2018:
    Doesn’t require a new wallet backup anymore, IIRC.

    laanwj commented at 12:28 pm on January 17, 2018:
    I don’t think it makes sense to update the documentation of a deprecated call, besides adding a DEPRECATED message and hiding it.

    meshcollider commented at 12:31 pm on January 17, 2018:
    Agreed, its not like backing up would actually be a bad thing anyway
  4. meshcollider commented at 12:32 pm on January 17, 2018: contributor
    utACK
  5. sipa commented at 12:35 pm on January 17, 2018: member
    utACK, thanks!
  6. laanwj added the label Wallet on Jan 17, 2018
  7. in src/wallet/rpcwallet.cpp:1305 in d0440d482c outdated
    1299@@ -1299,6 +1300,12 @@ UniValue addwitnessaddress(const JSONRPCRequest& request)
    1300         throw std::runtime_error(msg);
    1301     }
    1302 
    1303+    if (!IsDeprecatedRPCEnabled("addwitnessaddress")) {
    1304+        throw JSONRPCError(RPC_METHOD_DEPRECATED, "addwitnessaddress is deprecated and will be fully removed in v0.17. "
    1305+            "To use estimatefee in v0.16, restart bitcoind with -deprecatedrpc=estimatefee.\n"
    


    meshcollider commented at 12:47 pm on January 17, 2018:
    This still mentions estimatefee :)

    meshcollider commented at 12:47 pm on January 17, 2018:
    Also, if you deprecate it like this you’ll have to add -deprecatedrpc=addwitnessaddress to the tests which use it (easier than reworking the tests at the same time)

    laanwj commented at 1:06 pm on January 17, 2018:
    Gah, will update. Nothing is ever easy, is it? I assumed I was just updating the documentation hence I didn’t bother running any tests.
  8. Sjors commented at 1:20 pm on January 17, 2018: member
    Concept ACK
  9. laanwj commented at 1:26 pm on January 17, 2018: member

    The following tests are failing due to to the deprecation:

    • segwit.py
    • p2p-compactblocks.py
    • wallet-dump.py
    • nulldummy.py
    • bumpfee.py

    I’m starting to think this was a kind of bad idea, if we still rely so much on that call.

  10. MarcoFalke commented at 1:31 pm on January 17, 2018: member
    We can fix the test, but lets move the deprecation to 0.17 to not block 0.16?
  11. laanwj commented at 1:34 pm on January 17, 2018: member
    I don’t think anything needs to be blocked on that, just adding -deprecatedrpc=addwitnessaddress will do fine, I was just surprised there are so many.
  12. MarcoFalke added this to the milestone 0.16.0 on Jan 17, 2018
  13. in src/wallet/rpcwallet.cpp:1305 in 117ee54aa6 outdated
    1299@@ -1299,6 +1300,12 @@ UniValue addwitnessaddress(const JSONRPCRequest& request)
    1300         throw std::runtime_error(msg);
    1301     }
    1302 
    1303+    if (!IsDeprecatedRPCEnabled("addwitnessaddress")) {
    1304+        throw JSONRPCError(RPC_METHOD_DEPRECATED, "addwitnessaddress is deprecated and will be fully removed in v0.17. "
    1305+            "To use addwitnessaddress in v0.16, restart bitcoind with -deprecatedrpc=estimatefee.\n"
    


    flack commented at 2:57 pm on January 17, 2018:
    should say -deprecatedrpc=addwitnessaddress instead of -deprecatedrpc=estimatefee
  14. achow101 commented at 5:28 pm on January 17, 2018: member
    utACK modulo flack’s comment.
  15. ryanofsky commented at 9:35 pm on January 17, 2018: member
    utACK 117ee54aa62ddb43f039797d5496e014553f28ec with estimatefee fix and squash commits squashed (obviously)
  16. promag commented at 11:58 pm on January 17, 2018: member

    utACK after comments.

    We can slowly remove addwitnessaddress from the test suite right? For instance, #12213.

  17. wallet: Deprecate addwitnessaddress
    Now that segwit is natively supported by the wallet, deprecate the hack `addwitnessaddress`.
    cdf3e03a72
  18. laanwj force-pushed on Jan 18, 2018
  19. laanwj commented at 9:25 am on January 18, 2018: member

    fixed copy/paste error and squashed e849ae03c12f63a4ec591018983f28968d4f3dedcdf3e03a723b1a0242199672878caf1543ba8124

    We can slowly remove addwitnessaddress from the test suite right? For instance, #12213.

    Agreed. This deprecation made that an obligation before 0.17.0, not for 0.16.0, so could be done slowly but surely.

  20. laanwj merged this on Jan 18, 2018
  21. laanwj closed this on Jan 18, 2018

  22. laanwj referenced this in commit 17180fa608 on Jan 18, 2018
  23. jonasschnelli referenced this in commit eadb2dacc3 on Jan 24, 2018
  24. DrahtBot locked this on Sep 8, 2021

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 12:12 UTC

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