-
Notifications
You must be signed in to change notification settings - Fork 65
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
Change From Legacy Wallets To Descriptor Wallets Will Break A Ton Of Supporting Infrastructure #239
Comments
We were supposed to still be able to create legacy wallets via RPC commands, but after numerous attempts & research, I cannot get 8.22.0-rc4 to correctly generate legacy wallets correctly. I am not sure if this is a bug or if I am using the incorrect way of doing this. For example:
I get various errors such as no private keys exist, no wallet exists, and more. Doesnt seem to create a proper legacy wallet. Also the command |
I was able to finally figure out how to generate legacy wallets via digibyte-cli on digihash test pool with following commands:
Then to get an address for each wallet:
|
To generate a legacy address with just the "d" prefix I ran:
|
I will close this issue but it is important for people to know the descriptor change does require re-configuration of how keys are managed, addresses are generated and much legacy infrastructure will need to be updated. We should expect issues with pools and exchanges complaining about this. |
We can easy change it back. I created a PR @JaredTate |
Also nice that people know. If Digibyte 8 RC4 will be released there will be complains about legacy wallet. Because it freeze. #227 ( video in this pr ) when the wallet becomes to big. Plus legacy wallet is not turned off. Only default is set to descriptor. So with old wallets or by creating a new wallet getnewaddress "Walletname" "legacy" There is no difference in rpc. For any exchange or pool. |
I had my testnet descriptor wallet closed for 10 days. This is the wallet that is getting all my testnet mining rewards. When I opened it, it was taking a fairly long time to sync and then just crashed. It was frozen the whole time. I reopened it. It did open successfully this time, but it did freeze quite a bit while opening. There were close to 70million DGB in it, all coinbase TXs. So while I do think the small freezing that we had seen with the legacy wallet is better, it can still freeze while opening with a lot of new TXs. |
How many txs do you think are in the wallet? The amount doesn't matter as much as the number of txs. I once tried to open a DigiHash wallet with 100s of thousands of txs in a GUI back in 2016 and it would always crash, just too much data. This is why digibyted was made for servers. |
There were probably about 77,000 new TXs when I opened it after it was closed for 10 days. And that's just the coinbase TXs for what is currently in the wallet. A couple hundred million have already been sent out. Like when we discussed it while ago, people probably would not normally have the number of transactions that I do going through the QT wallet. |
Wow, yes that is a ton of TX's. Thank you for the feedback! I would bet that if you ran that same wallet via command line/ terminal on a server digibyted or locally you would have no issues. |
- Removed the unused descriptor checkbox from the wallet creation dialog. This change cleans up the UI and resolves compiler errors due to missing the `descriptor_checkbox` member by removing an unused element, improving the user experience. References: - #213 - #227 - #239 (comment)
It appears the change in RC4 to default to Descriptor Wallets Instead of Legacy Wallets is breaking a ton of infrastructure and causing it to need to be rewritten. Much of this is not an easy task as I have found out trying to get a digihash test mining pool up and running over the last week. Most of the supporting infrastructure built for DGB relies on legacy wallets and has been worked on for 10+ years now. I think we need to revert the changes and stick with legacy wallets in RC4 in the meantime. People can still make descriptor wallets if they want, but it breaks so much stuff it is going to be a disaster for us trying to get 3rd parties to upgrade to 8.22.
The following supporting infrastructure for sure breaks with the default change to descriptor wallets & move away from legacy wallets:
This change from legacy wallets to descriptor wallets is causing a ton of issues. It completely breaks the digihash nomp pool, and rewriting the mining pool is turning into quite the job. I have spent a couple days trying to re-configure digihash for test mining 8.22 rc4 and it's turning into a much more problematic situation than I expected.
For DigiHash test pool to be compatible with descriptor wallets the entire key management code, pool payouts code, and cryptography/key handling code needs re-written. Also, Code needs to be added for wallet management & many different RPC commands. It is not a simple task. This would also be needed for any closed-source exchange code & public DigiAssets infrastructure.
We simply do not have the team & people to re-write so much infrastructure. Or to provide support & know-how for this. Especially when the overwhelming majority of platforms making up not only DGB but BTC ecosystem still use legacy wallets.
The text was updated successfully, but these errors were encountered: