-
Notifications
You must be signed in to change notification settings - Fork 36.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Awesome multisig PR labyrinth guide #24861
Comments
Thanks @Sjors, this is very helpful. |
Thanks! It's definitely good to have an umbrella issue here, how to get to the point where it's more or less easy to do multisig with bitcoin core. |
Can you elaborate on your longer term plans for external signing / Boost Process. Process is currently relatively poorly maintained; bugs are remaining unfixed for multiple Boost releases, the code and issue tracking is confusingly spread across multiple repositories (which have different versions of the code), no recent "modernization" (i.e no option use If we continue to use it going forward, I think we need some sort of plan, addressing the above, rather than leaving it ignored while start accumulating workarounds in our own code to support it, and it's presence potentially blocks other goals. Happy to split this out into a separate issue for discussion. |
Ideally replace it, but I have no idea with what. That hasn't changed since 2019. In the original PR #15382 (comment) Garzik pointed an alternative from a 2016 blog post. Interesting that repo does have some ongoing development: https://github.com/arun11299/cpp-subprocess It doesn't support Windows (well) at the moment, but that might be acceptable since we already (temporally) Windows support anyway.
Indeed seems better to have a separate issue. Swapping out the implementation of |
I too had some concerns with one of the original PRs (#21935 (comment)) re: external signers. Revisiting this I think could be good. I typically build with That being said, my main goal is setting up (offline) multisig with Bitcoin Core, and I think it is many other people's goals to set up a wallet as you described in the OP - so thank you for setting up this umbrella issue Sjors! We are getting closer and closer to the final goal! I think some other PRs that could be good to add to the above tasklist would be: For Taproot support for external signers: (Besides the already linked #22558 in the OP):
Additional Miniscript PRs:
Descriptors
The GUI probably should be built with the new QML based fork? (https://github.com/bitcoin-core/gui-qml) @jarolrod @hebasto @Bosch-0 GUI:
BIPs to be supported:
I had set a $1,500 bounty for a GUI in Bitcoin Core that allows for the setting up of an (offline) multisignature wallet (here: #21071). Since then, there's been further work and standardization on this project. I am raising this bounty to $10,000, to be paid out in bitcoin. Payments will be made in part as individual tasklists are completed; to be divided up to developers who worked on the code and helped review it; at my discretion. This bounty update overrules and succeeds completely the original $1,500 bounty. Also: Addition:
Also, ultimately: So that threshold spends can be implemented privately Edit: Damn formatting |
Thanks for putting this together Sjors, mulitisg in core would be great. As @Rspigler mentioned, the QML project aims to be a more modern, user friendly version of the current GUI. Would be great for the GUI component of this effort was put towards the new QML framework. Imo putting a feature freeze on the widgets GUI and slowly moving towards QML as the project develops would prevent a lot of technical debt - something we don't have a lot of room for. Tagging others on the project for visibility @GBKS @promag @Mogashni. If you are looking ahead as to how an app like this would function, Nunchuk is a great example and imo easier to use than Specter. @hugohn |
Placed in my original post here |
@Sjors Can you update the title to show the bounty? Thanks. |
Should also add this to https://bitcoinbounties.org/ 👀 |
Submitted! |
Don't know about changing the title. I'll add a link to that site to the PR description once its added. |
Slightly updated the PR description, mainly: point to #26728 which replaces an earlier attempt, drop mention of potential NthKey MuSig2 support, since I discontinued that app. Are any other wallets working on MuSig2? |
Main momentum on MuSig2 is in #31245, which also links to a demo Ledger app. This still requires a fair amount of skill and copy-pasting to setup and use. |
@ryanofsky recently suggested that I should write an overview of how the various pull requests spread over different repositories relate to some bigger picture view.
See the multisig tutorial for how things currently work.
I typically have the following future multisig wallet in mind to guide my thinking:
The descriptors for this could be hand crafted, but it would be nice to have:
6. Miniscript compiler that can generate this
What's Missing?
createwalletdescriptor
andgethdkeys
RPCs for adding new automatically generated descriptors #29130 addedgethdkeys
, helpful but doesn't support arbitrary derivation pathscreatewallet
to generate a blank wallet, fetch an xpub from it, and then callimportdescriptors
.Misc
I have a PR that improves address display handling on the device:
Even better would be if we had a feature to ask the wallet for a signature to prove it has the private key (without passing that information to the outside world of course, see #24186). This requires BIP-322 support on our end (#24058), at least one hardware wallet to support it, and a new HWI
signmessage
command. Perhaps this can later be expanded to allow your device to prove that it (still) has the keys it needs as a co-signer.Miniscript compilers currently doesn't support Taproot (e.g. to find the optimal tree structure), but I'm assuming you can still hand craft a leaf containing MiniScript.
The text was updated successfully, but these errors were encountered: