LNPBP: 0003
Layer: Transaction (1)
Field: Cryptographic primitives
Title: Deterministic definition of transaction output containing cryptographic commitment
Author: Dr Maxim Orlovsky <orlovsky@pandoracore.com>
Comments-URI: https://github.com/LNP-BP/lnpbps/issues/5
Status: Draft
Type: Standards Track
Created: 2019-27-10
License: CC0-1.0
The standard defines an algorithm for deterministic definition of the transaction output containing cryptographic commitments made under the standards LNPBP-1 [1] and LNPBP-2 [2].
Embedding cryptographic commitments into Bitcoin blockchain has become a common practice [3]. Bitcoin blockchain provides strong guarantees on the underlying data immutability, presenting a reliable, distributed and censorship-resitent proof-of-publication [4] medium. While existing standards defines how the cryptographical commitments can be used with public keys on SECP256k1 elliptic curve (used by Bitcoin) and embedded within transaction outputs, it still has to be defined how the interested parties may detect which of a Bitcoin transaction output contains the commitment, presenting an interest to the party under some given protocol.
A number of use cases for cryptographic commitments (CC) require some commitment to be unique. For instance, single-use seals [5] may utilize them to achieve it's one-time commitment properties, as may be required in some of the applications [6], [7]. While the deterministic way for embedding into Bitcoin transactions (like "always use the first output) may be defined on a per-protocol basis, it seems that some best-practices, defining the best privacy-preserving and secure algorithm for such deterministic commitments in Bitcoin transactions may also be useful for the industry.
Some of the protocols relies on the first OP_RETURN output present in the transaction to contain the commitment [3]. However, this would not work for commitments supporting other output types ([2], [8]), and for may introduce collisions with other protocols using OP_RETURN, like OMNI Layer [9].
Static definition of the output containing the commitment will be incompatible with BIP-... [10], defining deterministic transaction output ordering and will not work with Lightning Network, following the same rules [11].
Cryptographic commitments under this standard are made according to LNPBP-1 [1] and LNPBP-2 [2] standards.
To deterministically define the number of transaction output that contains CC under some protocol P
, the committing
party "Alice" A
(which may be represented by a single person or some m-of-n federation) and the verifying party "Bob"
B
(which may be represented by a single person or some m-of-n federation) need to agree on three parameters:
- A protocol-defined parameter
s
, acting as a seed for all protocol-wide commitments, this must be a 8-bit value; - A commitment-specific parameter
c
, which should not be directly reflected in the transaction, containing a giver CC. This parameter under some circumstances, beforehand agreed by the parties, may be absent. The value ofc
must be a 8-bit value.
These two parameters serve as a "salt" for the deterministic procedure, preventing third-parties from guessing the information of the actual commitment, thus avoiding possible censorship by the miners and on-chain based transaction analysis.
Alice, creating the transaction containing CC, and Bob, verifying it, must use the following procedure:
- Compute the transaction fee
f
, as a difference between total transaction output amounts in satoshis and total inputs amounts, in satoshis:f = sum(outputs) - sum(inputs)
. According to the Bitcoin consensus rules, this amount must always be positive and greater than zero(f > 0
); otherwise it is not a valid Bitcoin transaction and the protocol must fail. - Compute the adjusted fee
a
as a 32-bit modulo of the potentially-64 bit numberf
:a = f mod 2^32
. - Add to this number a previously-agreed values of
s
andc
, or, ifc
was not defined, use0
forc
value by default. This will give a commitment-factorx = a + s + c
. Sinces
andc
is a 8-bit numbers anda
is a 32-bit number, the result MUST BE a 64-bit number, which will prevent any possible number overflows. - Get the number of outputs
n
for the transaction containing the output with the given cryptographic commitment - Compute
d
asd = x mod n
. Thed
will represent a number of transaction output which MUST contain a cryptographic commitment. All other transaction outputs under this protocol MUST NOT contain cryptographic commitments.
The proposed standard is incompatible with the existing practices for definition of the transaction output containing cryptographic commitment, namely:
- OpenTimestamps, putting the commitment into the first transaction output [1]
- ...
Nevertheless, use of protocol-specific pre-defined salt may be utilised as a flag signalling the support of the current standard, which will help to avoid possible commitment collisions across different protocols.
Future SIGHASH_NOINPUT standard BIP-118 [12] MAY BE compatible with this proposal, since a protocol utilizing the present
standard MAY define that any transaction commitment with an input signature flag set to SIGHASH_NOINPUT MUST default to
the zero value of commitment-specific parameter c
. This will still preserve the privacy from the onchain analysis
tools due to the presence of the protocol-specific parameter s
, which will be unknown for any party that does know
which protocol is used by some transaction (given the fact that the used protocol can't be guessed from the transaction
itself).
The rationale for the technical decision is provided within the specification text.
https://github.com/LNP-BP/rust-lnpbp/blob/master/src/commitments/tx.rs
Authors would like to thank Giacomo Zucco and Alekos Filini for their initial work on the commitment schemes as a part of early RGB effort [7].
- Maxim Orlovsky. Key tweaking: collision-resistant elliptic curve-based commitments (LNPBP-1 Standard). https://github.com/LNP-BP/lnpbps/blob/master/lnpbp-0001.md
- Maxim Orlovsky. Deterministic embedding of elliptic curve-based commitments into transaction outputs (LNPBP-2 standard). https://github.com/LNP-BP/lnpbps/blob/master/lnpbp-0002.md
- Peter Todd. OpenTimestamps: Scalable, Trust-Minimized, Distributed Timestamping with Bitcoin. https://petertodd.org/2016/opentimestamps-announcement
- Peter Todd. Setting the record straight on Proof-of-Publication. https://petertodd.org/2014/setting-the-record-proof-of-publication
- Peter Todd. Preventing Consensus Fraud with Commitments and Single-Use-Seals. https://petertodd.org/2016/commitments-and-single-use-seals
- Peter Todd. Scalable Semi-Trustless Asset Transfer via Single-Use-Seals and Proof-of-Publication. https://petertodd.org/2017/scalable-single-use-seal-asset-transfer
- OpenSeals Framework https://github.com/rgb-org/spec/blob/v1.0/01-OpenSeals.md
- Omni Protocol Specification (formerly Mastercoin). https://github.com/OmniLayer/spec
- RGB Protocol Specification, version 0.4. https://github.com/rgb-org/spec/blob/old-master/01-rgb.md
- Lexicographical Indexing of Transaction Inputs and Outputs (BIP-69 standard). https://github.com/bitcoin/bips/blob/master/bip-0069.mediawiki
- Lightning Network BOLT-3 standard. https://github.com/lightningnetwork/lightning-rfc/blob/v1.0/03-transactions.md
- Christian Decker. SIGHASH_NOINPUT. https://github.com/bitcoin/bips/blob/master/bip-0118.mediawiki
This document is licensed under the Creative Commons CC0 1.0 Universal license.
TBD