This document is a work-in-progress Bitcoin Improvement Proposal proposing Distributed Key Generation methods for use in FROST.
This document is licensed under the 3-clause BSD license.
In the FROST threshold signature scheme [KG20], a threshold t
of some set of n
signers is required to produce a signature.
FROST remains unforgeable as long as at most t-1
signers are compromised,
and remains functional as long as t
honest signers do not lose their secret key material.
As a result, threshold signatures increase both security and availability, enabling users to escape the inherent dilemma between the contradicting goals of protecting a single secret key against theft and data loss simultaneously. Before being able to create signatures, the FROST signers need to obtain a shared public key and individual key shares that allow to sign for the shared public key. This can, in principle, be achieved through a trusted dealer who generates the shared public key and distributes shares of the corresponding secret key to the FROST signers. However, the dealer is a single point of failure: if the dealer is malicious or compromised, or the secret key is not deleted correctly and compromised later, an adversary can forge signatures.
An interactive distributed key generation (DKG) protocol session by all signers avoids the need for a trusted dealer. There exist a number of DKG protocols with different requirements and guarantees. Most suitably for the use with FROST is the PedPop DKG (``Pedersen DKG with proofs of possession'') [KG20, CKM21, CGRS23]. But similar to most DKG protocols in the literature, PedPop has strong requirements on the communication between participants, which make it difficult to deploy PedPop in practice. It assumes that signers have secure (i.e., authenticated and encrypted) channels between each other to deliver secret shares to individual signers, and it assumes that signers have access to a secure broadcast mechanism.
- TODO Explain how funds are lost if broadcast doesn't work.
The aim of this document is to describe ChillDKG, a variant of PedPop with "batteries included", i.e., it incorporates minimal but sufficient implementations of secure channels and secure broadcast and thus is easy to deploy in practice.
The basic building block of our DKG protocol is the SimplPedPop protocol, which has been proven to be secure when combined with FROST [CGRS23]. The variant of SimplPedPop considered here is tailored for scenarios involving an untrusted coordinator, which enables bandwidth optimizations and is common also in implementations of the signing stage of FROST.
TODO: Say something about dishonest majority here, not only in the list below.
Besides external secure channels, SimplPedPod depends on an external equality check protocol. The equality check protocol serves an abstraction of a secure broadcast mechanism with limited functionality (TODO: this may be a confusing way to introduce the realtionship between equality check and broadcast. E.g., it doesn't only have limited functionality, it has more functionality as in broadcast only a single party broadcasts): Its only purpose is to check that, at the end of SimplPedPod, all participants have established an identical protocol transcript.
Our goal is to turn SimplPedPop into a standalone DKG protocol without external dependencies. We follow a modular approach that removes one dependency at a time. First, we take care of secure channels by wrapping SimplPedPop in a protocol EncPedPop, which relies on pairwise ECDH key exchanges between the participants to encrypt secret shares. Finally, we add a concrete equality check protocol to EncPedPop to obtain a standalone DKG protocol ChillDKG.
Our equality check protocol is inspired by the Goldwasser-Lindell echo broadcast [GW05] protocol. Crucially, it ensures that whenever some participant obtains a threshold public key as output of a successful DKG session, this honest participant will additionally obtain a transferable "success certificate", which can convince all other honest participants (ultimately at the time of a signing request) that the DKG has indeed been successful. This is sufficient to exclude the bad scenario described in the previous section. (TODO)
As an additional feature of ChillDKG, the state of any signing device can be fully recovered from a backup of a single secret per-device seed and the full public transcripts of all the DKG sessions in which the device was involved. ChillDKG thus incorporates solutions for both secure channels and broadcast, and simplifies backups in practice.
In summary, ChillDKG fits a wide range of usage scenarios, and due to its low overhead, we recommend ChillDKG even for applications which already incorporate secure channels or an existing broadcast mechanism such as a BFT protocol.
TODO: We could also mention (conditional) agreement and that it prevents losing coins, because it may not be a property supported by all DKGs. Also could mention "Modularity" since it's possible to wrap SimplPedPop in some other protocol.
In summary, we aim for the following design goals:
- Standalone: ChillDKG is fully specified, requiring no pre-existing secure channels or a broadcast mechanism.
- Dishonest Majority: ChillDKG supports any threshold
t <= n
(including "dishonest majority"t > n/2
). - Flexibility: ChillDKG supports a wide range of scenarios, from those where the signing devices are owned and connected by a single individual, to scenarios where multiple owners manage the devices from distinct locations.
- Simple backups: The capability of ChillDKG to recover from a static seed and public per-setup data impacts the user experience when backing up threshold-signature wallets. This can enhance the probability of having backups available, preventing users from losing access to their wallets.
- Support for Coordinator: Like the FROST signing protocol, ChillDKG supports a coordinator who can relay messages between the participants. This reduces communication overhead, because the coordinator is able to aggregate some some messages. A malicious coordinator can force the DKG to fail but cannot negatively affect the security of the DKG.
- DKG outputs per-participant public keys: When ChillDKG is used with FROST, partial signature verification is supported.
As a consequence of these design goals, ChillDKG inherit the following limitations:
- No robustness: Misbehaving signers can prevent the protocol from completing successfully. In such cases it is not possible to identify who of the signers misbehaved (unless they misbehave in certain trivial ways).
- Communication complexity not optimal in all scenarios: While ChillDKG is optimized for bandwidth efficiency and number of rounds under the premise of flexibility, there are conceivable scenarios where specialized protocols may have better communication complexity, e.g., when setting up multiple signing devices in a single location.
We give a brief overview of the low-level building block of ChillDKG, namely the DKG protocols SimplPedPop and EncPedPod. We stress that this document does not endorse the direct use of SimplPedPop or EncPedPod as DKG protocols. While SimplPedPop and EncPedPop may in principle serve as building blocks for other DKG designs (e.g., for applications that already incorporate a broadcast mechanism), this requires careful further consideration, which is not in the scope of this document. Consequently, we recommend implementations not to expose the algorithms of the building blocks as part of a high-level API targeted towards developers who are not cryptographic experts. (TODO Is this too arrogant? )
Detailed specifications of SimplPedPop and EncPedPop are provided in the form of a Python implementation.
The SimplPedPop scheme has been proposed in Practical Schnorr Threshold Signatures Without the Algebraic Group Model, section 4. It is an variant of the PedPop protocol [], an extension of Pedersen DKG []. As all variants of Pedersen DKG, SimplPedPop relies on Feldman's Verifiable Secret Sharing (VSS).
We make the following modifications as compared to the original SimplPedPop proposal:
- Adding individual's signer public keys to the output of the DKG. This allows partial signature verification.
- The participants send VSS commitments to an untrusted coordinator instead of directly to each other. This lets the coordinator aggregate VSS commitments, which reduces communication cost.
- The proofs of knowledge are not included in the data for the equality check. This will reduce the size of the backups in ChillDKG.
EncPedPop is a thin wrapper around that SimplPedPop. It takes care of encrypting the secret shares, so that they can be sent over insecure channels.
EncPedPod encrypts the shares to a 33-byte public key (as generated using BIP 327's IndividualPubkey algorithm).
TODO Write a high-level description of the eq protocol. It's probably a good idea to steal from the "background" section
ChillDKG is the DKG protocol proposed in this BIP. Its main advantages over existing DKG protocols are that it does not require any external secure channel or broadcast mechanism, and recovering a signer is securely possible from a single seed and the full transcript of the protocol.
TODO It's a wrapper around encpedpop
TODO Say something about the reference code
There are n >= 2
signers, t
of which will be required to produce a signature.
Each signer has a point-to-point communication link to the coordinator
(but signers do not have direct communication links to each other).
If there is no dedicated coordinator, one of the signers can act as the coordinator. (TODO This is like in MuSig, but we explained this differently in BIP327 where we say that the coordinator is optional...)
For each signer, the DKG has three outputs: a secret share, the shared public key, and individual public keys for partial signature verification. The secret share and shared public key are required by a signer to produce signatures and therefore, signers must ensure that they are not lost.
TODO: mention that these are properties when using the DKG with FROST
Some signers, the coordinator and all network links may be malicious, i.e., controlled by an attacker. We expect ChillDKG to provide the following informal security goals when it is used to setup keys for the FROST threshold signature scheme. (See TODO for a more formal treatment.)
If a session of the DKG protocol returns an output to an (honest) signer, then we say that this signer deems the protocol session successful. In that case, the output returned by the protocol session to the signer is a tuple consisting of a secret share (individual to the signer), the shared public key (common to all signers), a list of n individual public keys for partial signature verification (common to all signers), and a success certificate (common to all signers).
If a signer deems a protocol session successful, then this signer is assured that:
- A coalition of a malicious coordinator and at most
t - 1
malicious signers cannot forge signatures under that shared public key. (Unforgeability) - All (honest) signers who deem the protocol session successful will have correct and consistent protocol outputs.
In particular, they agree on the shared public key, the list of individual public keys and the success certificate.
Moreover, any
t
of them have secret shares which are, in principle, sufficient to reconstruct the secret key corresponding to the shared public key. This means that anyt
of have all the necessary inputs to session a successful FROST signing sessions that produce signatures valid under the shared public key. - The success certificate will, when presented to any other (honest) signer, convince that other signer to deem the protocol successful.
We stress that the mere fact one signer deems a protocol session successful does not imply that other signers deem it successful yet. That is exactly why the success certificate is necessary: If some signers have deemed the protocol not successful, but others have not (yet) and thus are stuck in the protocol session, e.g., due to failing network links or invalid messages sent by malicious signers, the successful signers can eventually make the stuck signers unstuck by presenting them a success certificate. The success certificate can, e.g., be attached to a request to initiate a FROST signing session.
If a DKG session succeeds from the point of view of an honest signer by outputting a shared public key,
then unforgeability is guaranteed, i.e., no subset of t-1
signers can create a signature.
TODO: Additionally, all honest signers receive correct DKG outputs, i.e., any set of t honest signers is able to create a signature.
TODO: consider mentioning ROAST
Generate long-term host keys.
chilldkg_hostkey_gen(seed: bytes) -> Tuple[bytes, bytes]
To initiate a concrete DKG session,
the participants send their host pubkey to all other participants and collect received host pubkeys.
We assume that the participants agree on the list of host pubkeys (including their order).
If they do not agree, the comparison of the session parameter identifier in the next protocol step will simply fail.
TODO: Params are the (ordered) list of host pubkeys (representing the signers) and threshold t
.
They then compute a session parameter identifier that includes all participants (including yourself TODO: this is maybe obvious but probably good to stress, in particular for backups).
SessionParams = Tuple[List[bytes], int, bytes]
chilldkg_session_params(hostpubkeys: List[bytes], t: int, context_string: bytes) -> Tuple[SessionParams, bytes]
The participants compare the session parameters identifier with every other participant out-of-band.
If a participant is presented a session parameters identifier that does not match the locally computed session parameters identifier, the participant aborts.
Only if all other n-1
session parameters identifiers are identical to the locally computed session parameters identifier, the participant proceeds with the protocol.
ChillDKGStateR1 = Tuple[SessionParams, int, EncPedPopR1State]
chilldkg_round1(seed: bytes, params: SessionParams) -> Tuple[ChillDKGStateR1, VSSCommitmentExt, List[Scalar]]
ChillDKGStateR2 = Tuple[SessionParams, bytes, DKGOutput]
chilldkg_round2(seed: bytes, state1: ChillDKGStateR1, vss_commitments_sum: VSSCommitmentSumExt, all_enc_shares_sum: List[Scalar]) -> Tuple[ChillDKGStateR2, bytes]
A return value of False means that cert
is not a valid certificate.
You MUST NOT delete state2
in this case.
The reason is that some other participant may have a valid certificate and thus deem the DKG session successful.
That other participant will rely on us not having deleted state2
.
Once you obtain that valid certificate, you can call chilldkg_finalize
again with that certificate.
chilldkg_finalize(state2: ChillDKGStateR2, cert: bytes) -> Union[DKGOutput, Literal[False]]
TODO Write
TODO Does it make sense to keep these function signatures?
chilldkg(chan: SignerChannel, seed: bytes, my_hostseckey: bytes, params: SessionParams) -> Union[Tuple[DKGOutput, Any], Literal[False]]
chilldkg_coordinate(chans: CoordinatorChannels, params: SessionParams) -> Union[GroupInfo, Literal[False]]
Losing the secret share or the shared public key will render the signer incapable of participating in signing sessions. As these values depend on the contributions of the other signers to the DKG, they can, unlike secret keys in BIP 340 or BIP 327, not be derived solely from the signer's seed.
To facilitate backups of a DKG session,
ChillDKG offers the possibility to recover a signer's outputs of the session from the signer's seed and the DKG transcript of the specific session.
As a result, a full backup of a signer consists of the seed and the transcripts of all DKGs sessions the signer has participated in.
(TODO Which sessions? Probably all sessions deemed successful, i.e., the backup should be exported as part of finalize
.)
Since the transcript is verifiable and the same for all signers,
if a signer loses the backup of the transcript of the DKG session,
they can request it from any other signers or the coordinator.
Moreover, since the transcript contains secret shares only in encrypted form,
it can in principle be stored with a third-party backup provider.
(TODO: But there are privacy implications. The hostpubkeys and shared public key can be inferred from the transcript. We could encrypt the full transcript to everyone... We'd only need to encrypt a symmetric key to everyone.)
chilldkg_backup(state2: ChillDKGStateR2, cert: bytes) -> Any
chilldkg_recover(seed: bytes, backup: Any, context_string: bytes) -> Union[Tuple[DKGOutput, SessionParams], Literal[False]]
Note that it may not be an unreasonable strategy in a threshold setup not to perform backups of signers at all,
and simply hope that t
honest and working signers will remain available.
As soon as one or more signers are lost or broken, new DKG session can be performed with the unavailable signers replaced.
One drawback of this method is that it will result in a change of the shared public key,
and the application will, therefore, need to transition to the new shared public key
(e.g., funds stored under the current shared public key need to be transferred to the new key).
Whether to perform backups and how to manage them ultimately depends on the requirements of the application, and we believe that a general recommendation is not useful.
TODO: make the following a footnote There are strategies to recover if the backup is lost and other signers assist in recovering. In such cases, the recovering signer must be very careful to obtain the correct secret share and shared public key!
- If all other signers are cooperative and their seed is backed up (EncPedPop or ChillDKG), it's possible that the other signers can recreate the signer's lost secret share.
- If threshold-many signers are cooperative, they can use the "Enrolment Repairable Threshold Scheme" described in these slides. This scheme requires no additional backup or storage space for the signers. These strategies are out of scope for this document.
TODO: The term agreement is overloaded (used for formal property of Eq and for informal property of DKG). Maybe rename one to consistency? Check the broadcast literature first
A crucial prerequisite for security is that participants reach agreement over the results of the DKG.
Indeed, disagreement may lead to catastrophic failure:
For example, assume that all but one participant believe that DKG has failed and therefore delete their secret key material,
but one participant believes that the DKG has finished successfully and sends funds to the resulting threshold public key.
Then those funds will be lost irrevocably, because, assuming t > 1
, the single remaining secret share is not sufficient to produce a signature.
DKG protocols in the cryptographic literature often abstract away from this problem by assuming that all participants have access to some kind of ideal "reliable broadcast" mechanism, which guarantees that all participants receive the same protocol messages and thereby ensures agreement. However, it can be hard or even theoretically impossible to realize a reliable broadcast mechanism depending on the specifics of the application scenario, e.g., the guarantees provided by the underlying network, and the minimum number of participants assumed to be honest.
The DKG protocols described in this document work with a similar but slightly weaker abstraction instead. They assume that participants have access to an equality check mechanism "Eq", i.e., a mechanism that asserts that the input values provided to it by all participants are equal.
TODO: Is it really the DKG that is successful here or is it just Eq?
Eq has the following abstract interface: Every participant can invoke Eq(x) with an input value x. Eq may not return at all to the calling participant, but if it returns, it will return True (indicating success) or False (indicating failure).
- True means that it is guaranteed that all honest participants agree on the value x (but it may be the case that not all of them have established this fact yet). This means that the DKG was successful and the resulting aggregate key can be used, and the generated secret keys need to be retained.
- False means that it is guaranteed that no honest participant will output True. In that case, the generated secret keys can safely be deleted.
As long as Eq(x) has not returned for some participant, this participant remains uncertain about whether the DKG has been successful or will be successful. In particular, such an uncertain participant cannot rule out that other honest participants receive True as a return value and thus conclude that the DKG keys can be used. As a consequence, even if Eq appears to be stuck, the caller must not assume (e.g., after some timeout) that Eq has failed, and, in particular, must not delete the DKG state and the secret key material.
TODO Add a more concrete example with lost funds that demonstrates the risk?
While we cannot guarantee in all application scenarios that Eq() terminates and returns, we can typically achieve a weaker guarantee that covers agreement in the successful cases. Under the assumption that network messages eventually arrive (this is often called an "asynchronous network"), we can guarantee that if some honest participant determines the DKG to be successful, then all other honest participants determine it to be successful eventually.
More formally, Eq must fulfill the following properties:
- Integrity: If some honest participant outputs True, then for every pair of values x and x' input provided by two honest participants, we have x = x'.
- Conditional Agreement: If some honest participant outputs True and the delivery of messages between honest participants is guaranteed, then all honest participants output True.
Conditional agreement does not guarantee that the protocol terminates if two honest participants have x
and x'
such that x != x'
.
To ensure termination in that situation, the protocol requires a stronger property:
- (Full) Agreement: If the delivery of messages between honest participants is guaranteed, all honest participants will output True or False.
TODO: Expand these scenarios. Relate them to True, False.
Depending on the application scenario, Eq can be implemented by different protocols, some of which involve out-of-band communication:
In a scenario where a single user employs multiple signing devices (e.g., hardware wallets) in the same room to establish a threshold setup, every device can simply display its value x (or a hash of x under a collision-resistant hash function) to the user. The user can manually verify the equality of the values by comparing the values shown on all displays, and confirm their equality by providing explicit confirmation to every device, e.g., by pressing a button on every device.
TODO add failure case, specify entire protocol
Similarly, if signing devices are controlled by different organizations in different geographic locations, agents of these organizations can meet in a single room and compare the values.
These "out-of-band" methods can achieve agreement (assuming the involved humans proceed with their tasks eventually).
The equality check protocol used by ChillDKG is applicable to network-based scenarios where long-term host keys are available. It satisfies integrity and conditional agreement.
Proof. (TODO for footnote?)
Integrity:
Unless a signature has been forged, if some honest participant with input x
outputs True,
then by construction, all other honest participants have sent a signature on x
and thus received x
as input.
Conditional Agreement:
If some honest participant with input x
returns True,
then by construction, this participant sends a list cert
of valid signatures on x
to every other participant.
Consider any honest participant among these other participants.
Assuming a reliable network, this honest participant eventually receives cert
,
and by integrity, has received x
as input.
Thus, this honest participant will accept cert
and return True.
If the participants run a BFT-style consensus protocol (e.g., as part of a federated protocol), they can use consensus to check whether they agree on x
.
TODO: Explain more here. This can also achieve agreement but consensus is hard (e.g., honest majority, network assumptions...)