Closes #11348
Adds a -walletdir
parameter which specifies a directory to use for wallets, allowing them to be stored separately from the ‘main’ data directory. Creates a new wallets/
directory in datadir if this is the first time running, and defaults to using it if it exists.
Includes tests and release notes. Things which might need to be considered more:
- there is no ’lock’ on the wallets directory, which might be needed?
- because this uses a new wallets/ directory by default, downgrading to an earlier version won’t see the wallets in that directory (not a big deal though, users can just copy them up to the main dir)
- jnewbery suggested putting each wallet in its own directory, which is a good idea, but out of scope for this PR IMO. EDIT: this is being done in #11687
- doc/files.md needs updating (will do soon)
I also considered including a cleanup by removing caching of data directory paths and instead just initialise them once on startup (c.f. #3073), but decided it wasn’t super relevant here will just complicate review.