mirror of
https://github.com/bitcoin/bips.git
synced 2025-01-18 05:12:47 +01:00
Merge pull request #1593 from jonatack/2024-05-bip388-fixups
BIP388 fixups
This commit is contained in:
commit
77f081789f
@ -65,7 +65,7 @@ We set two fundamental design goals:
|
||||
* Minimize the amount of information that is shown on screen - so that the user can actually validate it.
|
||||
* Minimize the number of times the user has to validate such information.
|
||||
|
||||
Designing a secure protocol for the coordination of a descriptor wallet among distant parties is also a challenging problem that is out of scope in this document. See [[bip-00129.mediawiki|BIP-129 (Bitcoin Secure Multisig Setup)]] for an approach designed for multisignature wallets. Regardless of the approach, the ability for the user to carefully verify all the details of the spending policies using the hardware signer's screen is a prerequisite for security in adversarial environments.
|
||||
Designing a secure protocol for the coordination of a descriptor wallet among distant parties is also a challenging problem that is out of scope in this document. See [[bip-0129.mediawiki|BIP-129 (Bitcoin Secure Multisig Setup)]] for an approach designed for multisignature wallets. Regardless of the approach, the ability for the user to carefully verify all the details of the spending policies using the hardware signer's screen is a prerequisite for security in adversarial environments.
|
||||
|
||||
=== Policy registration as a solution ===
|
||||
|
||||
@ -136,7 +136,7 @@ A ''wallet descriptor template'' is a <tt>SCRIPT</tt> expression.
|
||||
* ''always'' followed by either:
|
||||
** the string <tt>/**</tt>, or
|
||||
** a string of the form <tt>/<NUM;NUM>/*</tt>, for two distinct decimal numbers <tt>NUM</tt> representing unhardened derivations, or
|
||||
** any of the additional, implementation-specific valid derivation path patterns (see [[#Optional_derivation_paths|Optional derivation paths]] below).
|
||||
** any of the additional, implementation-specific valid derivation path patterns (see [[#optional-derivation-paths|Optional derivation paths]] below).
|
||||
|
||||
The <tt>/**</tt> in the placeholder template represents commonly used paths for receive/change addresses, and is equivalent to <tt><0;1>/*</tt>.
|
||||
|
||||
@ -294,7 +294,7 @@ Wallet policies are implemented in
|
||||
* the [https://github.com/digitalbitbox/bitbox02-firmware BitBox02 firmware] since version v9.15.0;
|
||||
* [https://github.com/Blockstream/Jade Blockstream Jade] since version v1.0.24, via [https://github.com/ElementsProject/libwally-core libwally-core] v1.0.0.
|
||||
|
||||
For development and testing purposes, we provide a [[bip-wallet-policies/wallet_policies.py|Python 3.7 reference implementation]] of simple classes to handle wallet policies, and the conversion to/from output script descriptors.
|
||||
For development and testing purposes, we provide a [[bip-0388/wallet_policies.py|Python 3.7 reference implementation]] of simple classes to handle wallet policies, and the conversion to/from output script descriptors.
|
||||
The reference implementation is for demonstration purposes only and not to be used in production environments.
|
||||
|
||||
==Footnotes==
|
||||
|
2
bip-0388/wallet_policies.py
Normal file → Executable file
2
bip-0388/wallet_policies.py
Normal file → Executable file
@ -1,3 +1,5 @@
|
||||
#!/usr/bin/env python3
|
||||
|
||||
from typing import Iterable, List, Mapping, Tuple, Generator
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user