Return-Path: Received: from smtp1.linuxfoundation.org (smtp1.linux-foundation.org [172.17.192.35]) by mail.linuxfoundation.org (Postfix) with ESMTPS id A2B43AB8 for ; Fri, 8 Sep 2017 20:14:36 +0000 (UTC) X-Greylist: from auto-whitelisted by SQLgrey-1.7.6 Received: from so254-16.mailgun.net (so254-16.mailgun.net [198.61.254.16]) by smtp1.linuxfoundation.org (Postfix) with ESMTPS id 290D912A for ; Fri, 8 Sep 2017 20:14:34 +0000 (UTC) DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=suredbits.com; q=dns/txt; s=mailo; t=1504901673; h=Content-Type: Cc: To: Subject: Message-ID: Date: From: References: In-Reply-To: MIME-Version: Sender; bh=TdjBzIcSuzhaLrxbiphggqpM0zAmTyM3CgbSG97Y5zs=; b=gv5HCUzmBl2YpFChMkRQ15NIdPdOF4t+XcWQWg6frr1q3nN/3+euopfHsq+lcxKWlg+qqjur xWcok2ARYLLjnsrKkQcG3/kPcnEgXRi5u6cfFmjP15/agtzQCZS9ry1El13J9utY7PyhGesH BTQhIg1xLMz3IgMw9nq/G2HqZck= DomainKey-Signature: a=rsa-sha1; c=nofws; d=suredbits.com; s=mailo; q=dns; h=Sender: MIME-Version: In-Reply-To: References: From: Date: Message-ID: Subject: To: Cc: Content-Type; b=koC6S6yN9R+xHh6Runs36ODn6XOAI5/ZlO9h0Adj5OSk+Bwa1zsy3Li+iVe1aWIdW0a1YD Zm55KGx0LFzMhBX35TijIhTszY9b20YOHpU6zemrG4XE1YJvwXCk72WtoRUqXVLv61bL+uSy tly12gShP9YmQTCJr1JFnaTI4cKWQ= Sender: chris@suredbits.com X-Mailgun-Sending-Ip: 198.61.254.16 X-Mailgun-Sid: WyI5MGYzNyIsICJiaXRjb2luLWRldkBsaXN0cy5saW51eGZvdW5kYXRpb24ub3JnIiwgIjJjMTQxIl0= Received: from mail-it0-f47.google.com (mail-it0-f47.google.com [209.85.214.47]) by mxa.mailgun.org with ESMTP id 59b2fa27.7ff6c84810f0-smtp-out-n01; Fri, 08 Sep 2017 20:14:31 -0000 (UTC) Received: by mail-it0-f47.google.com with SMTP id c195so5222116itb.1 for ; Fri, 08 Sep 2017 13:14:31 -0700 (PDT) X-Gm-Message-State: AHPjjUjzCwztPEpsYO9AJhHNr24SYZWWHGpbZBkUE8tkQZDEbTeLB8LG QwWMDiVI2CBOf1cuJEQx9GktObX0/F+oAe9HfHA= X-Google-Smtp-Source: ADKCNb4gjZdArS1nlnT1ACN5A5KZwsIzVWDhHdgldhsO+TUCdTHt8VpcfxmuL0z5leKmeU7KSUzesOm15QgudSWTnYs= X-Received: by 10.36.213.212 with SMTP id a203mr2627908itg.59.1504901670883; Fri, 08 Sep 2017 13:14:30 -0700 (PDT) MIME-Version: 1.0 Received: by 10.107.10.20 with HTTP; Fri, 8 Sep 2017 13:14:30 -0700 (PDT) In-Reply-To: References: From: Chris Stewart Date: Fri, 8 Sep 2017 15:14:30 -0500 X-Gmail-Original-Message-ID: Message-ID: To: ZmnSCPxj Content-Type: multipart/alternative; boundary="94eb2c05d7c483e5bc0558b33941" X-Spam-Status: No, score=0.4 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HTML_MESSAGE,RCVD_IN_DNSWL_NONE,RCVD_IN_SORBS_SPAM autolearn=disabled version=3.3.1 X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on smtp1.linux-foundation.org X-Mailman-Approved-At: Sat, 09 Sep 2017 03:28:16 +0000 Cc: Bitcoin Protocol Discussion Subject: Re: [bitcoin-dev] Sidechain headers on mainchain (unification of drivechains and spv proofs) X-BeenThere: bitcoin-dev@lists.linuxfoundation.org X-Mailman-Version: 2.1.12 Precedence: list List-Id: Bitcoin Protocol Discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 08 Sep 2017 20:14:36 -0000 --94eb2c05d7c483e5bc0558b33941 Content-Type: text/plain; charset="UTF-8" Hi ZmnSCPxj, However, a lockbox on one chain is a WT on the other > chain. We can create a free lockbox on Ess, then use that lockbox as > a WT on Tee, inflating TeeCoin. I'm not sure if I follow what you are saying here. What do you mean by 'free lockbox'? I was assuming that I created an arbitrary blockchain, say ChrisChain, that is NOT pegged to the bitcoin blockchain? I.e. the tokens on ChrisChain are worthless. Then I create a lockbox on ChrisChain with my worthless tokens and attempt to transfer them into TeeCoin's chain? However this doesn't make sense with However, this parameter is used to determine if it is a WT. Sidechain > consensus should require that freely-created lockboxes set this > parameter to 0, so that a side block that creates free lockboxes where > this parameter is non-zero is an invalid side block. Then a sidechain > will only treat a lockbox on another chain as a WT if the wtFlag > parameter is nonzero. This way, freely-created lockboxes are not > valid WT. Valid WT must lock actual, already unlocked coins, not > create new locked coins. > because I could arbitrarily set this parameter to 0. It seems that a sidechain upon inception should pay all of it's tokens to a single UTXO and prevent minting of coins after that. I'm fairly certain this is what elements does in it's genesis block. The is unrelated to the problem above, but it will be a problem in sidchain-headers-on-mainchain if we have a limited amount of mining slots in the coinbase_tx output vector. Let us assume we have a fixed set of sidechain slots in the coinbase output vector, in this case 10. However there are 15 competing sidechains for these 10 slots. It may be possible for sidechains (say 15 sidechains) to compete indefinitely for these 10 slots -- causing indefinite forks. Let us say sidechain 10 and sidechain 11 alternate block hashes in coinbase_tx.vout[10] output. This means that a WT^ will never be considered valid because it will appear to mainchain miners that there are competing forks of the SAME sidechain, when in reality it is two unique sidechains competing to mine the the limited coinbase output vector space. -Chris On Fri, Sep 8, 2017 at 9:56 AM, ZmnSCPxj wrote: > Good morning, > > Chris mentioned the use of OP_WITHDRAWPROOFVERIFY. I've come to realize > that this is actually superior to use OP_WITHDRAWPROOFVERIFY with a > sidechain-headers-on-mainchain approach. > > Briefly, a payment to OP_WITHDRAWPROOFVERIFY is an instruction to transfer > value from the mainchain to a sidechain. Thus, a payment to > OP_WITHDRAWPROOFVERIFY includes the sidechain to pay to, and a commitment > to a sidechain address (or whatever is the equivalent to a sidechain > address). > > Various OP_WITHDRAWPROOFVERIFY explanations exist. Most of them include > OP_REORGPROOFVERIFY. With sidechain-headers-on-mainchain, however, there > is > no need for reorg proofs. This is because, the mainchain can see, in real > time, which branch of the sidechain is getting extended. Thus if someone > attempts to defraud a sidechain by forking the sidechain to an invalid > state, sidechainers can immediately detect this on the mainchain and > immediately act to prevent the invalid fork from being advanced. After > all, a reorg proof is really just an SPV proof that is longer than some > previous SPV proof, that shows that the previous SPV proof is incorrect, > by showing that the block at the specified height of the WT is not present > on a longer SPV proof. > > Since sidechain-headers-on-mainchain implies merge mining of sidechains, > with no option to have independent proof-of-work of sidechains, the > sidechain's entire history is recorded on the mainchain, visible to all > mainchain nodes. > > -- > > An advantage of sidechain-headers-on-mainchain is a side-to-side peg > without > passing through the mainchain. > That is, a 2-way peg between any two chains, whether side or main. > > Sidechains supporting side-to-side transfer would require supporting > OP_WITHDRAWPROOFVERIFY, but not any of the other parts of sidechains. > > We must consider a WT format (withdrawal transaction) that is compatible > with an OP_WITHDRAWPROOFVERIFY Bitcoin transaction. > > ***That is, a lockbox UTXO on one chain is a WT on another chain.*** > > Sidechains need not follow the mainchain format for its normal > transactions, only for WT transactions that move coins across chains. > > For this, mainchain should also have its own "sidechain ID". Perhaps a > sidechain ID of 0 would be appropriate for mainchain, as its status as > mainchain. > > Suppose we have two sidechains, Ess and Tee, both of which support > side-to-side pegs. > > An Ess fullnode is a Bitcoin fullnode, but an Ess fullnode is not > necessarily a Tee fullnode, and vice versa. > > A lockbox redemption in sidechain-headers-on-mainchain is simply a spend of > a lockbox, pointing to the sidechain header containing WT, the merkle tree > path to the WT transaction from the h* commitment of the header, the output > which locks, and so on as per usual OP_WITHDRAWPROOFVERIFY. > > Then a sidechain can create tokens from nothing, that are locked in a > OP_WITHDRAWPROOFVERIFY lockbox; this is the only way to create sidecoin. > When transferring into a sidechain from mainchain, or anywhere, the > sidechain either creates tokens locked into OP_WITHDRAWPROOFVERIFY, or > looks for an existing UTXO with OP_WITHDRAWPROOFVERIFY from the source > chain and spends them (the latter is preferred as it is fewer > transactions and less space on the sideblock, reducing sidechain fees). > > OP_WITHDRAWPROOFVERIFY on a sidechain would query the mainchain fullnodes. > Whatever rules allow lockbox unlocking on mainchain, will also be the same > rules that allow lockbox unlocking on sidechains. > A mainchain RPC can even be made to simplify sidechain verification of > side-to-side pegs, and to ensure that sidechains follow the same consensus > rules for OP_WITHDRAWPROOFVERIFY. > > So if we want transfer TeeCoin to EssCoin, we spend into a > OP_WITHDRAWPROOFVERIFY lockbox on Teechain pointing to Esschain (i.e. a > Tee->Ess lockbox). This lockbox is itself a WT from the point of view of > Esschain. On Esschain, we look for an existing Ess->Tee lockbox, or > create a Ess->Tee lockbox of our own for a EssCoin fee. Then we create a > spend of the Ess->Tee lockbox on Esschain, wait until spending is > possible, and then post that transaction on Esschain. > > Again, with sidechain-headers-on-mainchain, reorg proofs are unnecessary, > since any invalid chain should be quickly buried by a valid chain, > unless the economic majority decides that a sidechain is not worth > protecting. > > -- > > All is not well, however. Remember, on a sidechain, we can create new > sidecoin for free, provided they are in a lockbox. Unlocking that > lockbox would require a valid WT on the chain that the lockbox is > dedicated to. However, a lockbox on one chain is a WT on the other > chain. We can create a free lockbox on Ess, then use that lockbox as > a WT on Tee, inflating TeeCoin. > > Instead, we add an additional parameter, wtFlag, to > OP_WITHDRAWPROOFVERIFY. > This parameter is ignored by OP_WITHDRAWPROOFVERIFY opcode. > > However, this parameter is used to determine if it is a WT. Sidechain > consensus should require that freely-created lockboxes set this > parameter to 0, so that a side block that creates free lockboxes where > this parameter is non-zero is an invalid side block. Then a sidechain > will only treat a lockbox on another chain as a WT if the wtFlag > parameter is nonzero. This way, freely-created lockboxes are not > valid WT. Valid WT must lock actual, already unlocked coins, not > create new locked coins. > > On Bitcoin, of course, this parameter must always be nonzero, since > freely-created lockboxes are not allowed on mainchain, as asset > issuance on mainchain is already fixed. > > -- > > Let us now flesh out how WT and lockboxes look like. As we mentioned, a > lockbox on one chain is a WT on the destination chain. Or to be more > precise, what a destination chain sees as a WT, is a lockbox on the source > chain. > > Thus, a lockbox is a Bitcoin-formatted transaction output paying to the > scriptPubKey: > > OP_WITHDRAWPROOFVERIFY > > (assuming a softfork, additional OP_DROP operations may occur after > OP_WITHDRAWPROOFVERIFY) > > Suppose the above lockbox is paid to in the Bitcoin mainchain, with the > sidechain ID being the ID of Esschain. This is itself a WT transaction > from the point of view of Esschain, on the principle that a lockbox on > one chain is a WT on another chain. > > Assuming Esschain is a brand-new sidechain, it has no EssCoins yet. The > sidechain allows the arbitrary creation of sidecoin provided the new > sidecoins are in a lockbox whose sidechain address commitment is 0. So > in Esschain, we create the same coins on a UTXO paying to the > scriptPubKey: > > 0 0 OP_WITHDRAWPROOFVERIFY > > The first 0 is the sidechain address commitment, which is 0 since this > output was not created by transferring to a sidechain; we > reuse the sidechain address commitment as the wtFlag. The > second 0 is the mainchain's ID. The above is a lockbox from the point of > view of Esschain. It is not a WT on mainchain, however, because the > sidechain address commitment is 0, which we use also as the wtFlag > parameter. > > Now, how does a main-to-side peg work? After creating the above output on > Esschain, we now spend the output with the below scriptSig: > > transaction> > > On Esschain, OP_WITHDRAWPROOFVERIFY then verifies that the mainchain block > hash is a valid past block of the mainchain, then locates the mainchain > header. It then checks the merkle tree path to the mainchain WT > transaction, > confirming that the mainchain contains that transaction, and confirms that > the > indicated output is in fact, a payment to an OP_WITHDRAWPROOFVERIFY, which > pushes the Esschain ID, and with a nonzero sidechain address commitment. > > (Esschain also needs to ensure that a single WT is not used to unlock > multiple lockboxes on Esschain; the easiest way is to add it to a set, > but this set cannot be pruned; other ways of ensuring only a WT is only > used to unlock once might be designed) > > On Esschain, the sidechain does one final check: the transaction that > spends > an OP_WITHDRAWPROOFVERIFY must have an output that pays to the sidechain > address committed to, and that output's value must be the same as the value > locked in the mainchain. > > (for now, I think all lockboxes must have the same fixed amount, for > simplicity) > > Now suppose we want to convert back our EssCoin to Bitcoin. We create a > lockbox on Esschain, paying to the below: > > 0 OP_WITHDRAWPROOFVERIFY > > The bitcoin P2SH address is mainchain address commitment; for simplicity > we just use P2SH on mainchain as it can encode any address. The 0 is the > mainchain ID. The above Esschain lockbox is itself a WT from Esschain to > mainchain. > > Then, we look for an unspent lockbox on Esschain whose sidechain ID is the > Esschain ID. Note that we can select any lockbox with the correct > sidechain ID, regardless of the sidechain address commitment it may have. > > Locating an appropriate mainchain lockbox for Esschain coins, we then > provide the below scriptSig, paying out to the bitcoin P2SH address we > selected: > > block header hash> > > On mainchain, we check that the indicated sidechain block header hash is a > block header on the longest chain of Esschain. We check it has sufficient > depth. Then we check if the merkle path to the WT tx is correct and goes > to esschain WT tx. Finally, we check the indicated output ID, and check > that > it is indeed an Esschain lockbox dedicated to mainchain. Finally, we check > that the transaction has an output that spends the lockbox amount to the > specified bitcoin P2SH address. > > (similarly mainchain nees to ensure that the Esschain WT is only used > once) > > The key insight here is that side-to-side pegs are just like side-to-main > pegs. Suppose instead we want to transfer our coins from Esscoin to > Teecoin. We would instead pay to the following lockbox on Esschain: > > OP_WITHDRAWPROOFVERIFY > > Then a Teechain transaction spending some Tee->Ess lockbox (or a fresh > lockbox if there are no Tee->Ess lockboxes on Teechain) is created. > We proceed as if it were a side-to-main peg, except it is a peg to > Teechain, either creating or unlocking TeeCoins. Indeed, mainchain > fullnodes may even provide an RPC for checking OP_WITHDRAWPROOFVERIFY, > so as to reduce risk that a sidechain breaks consensus due to buggy > code. > > -- > > All is still not well with side-to-side pegs, however. > > Suppose the economic majority decides that Esschain must die. Perhaps it > has some irrecoverable security bug, perhaps it adds features that allow > Esschain fullnodes to kill baby seals, perhaps a successful theft of > Esschain lockboxes was performed and Esscoins are now functionally > worthless. Killing a sidechain is done by bribing miners to put invalid > values into h*, and thus stealing Bitcoin->Ess lockboxes. > > If Esschain dies, however, and the economic majority is not prepared to > keep > Esschain dead, it is possible to unlock Tee->Ess lockboxes on Teechain. > Unlocking existing Tee->Ess lockboxes on Teechain is safe, since they > represent coins that were locked into Bitcoin->Tee lockboxes. However, > it is still possible to create "free" Tee->Ess lockboxes on Teechain, then > provide an invalid Tee->Ess WT lockbox on the now-moribund Esschain to > unlock the free Tee->Ess lockbox on Teechain, inflating TeeCoin value. > Thus in the presence of side-to-side pegs, the death of even one sidechain > represents the death of every other sidechain! > > Thus, to properly kill Esschain, the economic majority should spam the > Esschain headers slot with a fixed value, say 0, forever. This makes it > very difficult to create a Tee->Ess WT lockbox on Esschain, as you would > now be able to reverse a one-way hash function. > > Alternatively, Teechain can softfork so that Tee->Ess lockboxes are no > longer creatable or spendable. However, the death of Esschain requires > that all other sidechains, including Youchain, Veechain, Dubyachain, and > so on, to softfork similarly. > > Perhaps both can be done: first the economic majority wanting to kill > Esschain starts spamming it with invalid spends of Bitcoin->Ess lockboxes, > then when all Bitcoin->Ess lockboxes have been stolen, spam it with 0s > until all other sidechains have banned free Ess lockboxes on their chains. > Then, the economic majority can leave Esschain dead, and a later softfork > of mainchain prevents Esschain from being extended and allows mainchain > fullnodes to prune Esschain headers. > > -- > > Thieves will still have the same difficulty stealing from sidechains, but > now their payoff is increased. If a thief wants to steal Esschain > lockboxes, then it is possible to pack an invalid Esschain block full of > invalid WT to other chains. Even chains that don't have lockboxes to > Esschain can create lockboxes to Esschain for free. Thus, instead of > stealing only one lockbox at a time on mainchain, the thief can steal one > lockbox on mainchain, and on every sidechain that supports side-to-side > pegs, at a time. The risk/reward ratio may shift drastically in that case. > > However, this does mean that users of one chain must pay attention to > attacks on other chains, not just the chain they use. If Teechain has no > side-to-side pegs, then Teechain users will not care if Esschain is under > attack. But if side-to-side pegs are allowed on Teechain, then Teechain > users must also care about Esschain's health, as well as the health of > every other sidechain in existence. Mainchain is protected since free > lockboxes are not creatable on mainchain. Each sidechain is not; thus > the user of any sidechain must also stand by users of every other > sidechain, or else they all fall apart. Of course, this could more > simply lead to "I will not use Teechain even if it would be useful to me, > because if I use Teechain, I have to care about Esschain and Youchain and > whatever." > > -- > > Side-to-side pegs are useful to allow better liquidity and provide > arbitrage quickly between sidechains, without having to pass through > mainchain. Otherwise, Esscoin may be valued slightly lower than Bitcoin, > then Teecoin valued slightly higher than Bitcoin, creating a larger > difference between Esscoin and Teecoin values than what a full > side-to-side peg could support. 2-way pegs from mainchain > to sidechain stabilize sidecoin with respect to maincoin. Side-to-side > pegs stabilize all sidecoins to all other sidecoins. > > Side-to-side pegs are enabled implicitly by sidechain-headers-on- > mainchain, > as all sidechain fullnodes must necessarily be mainchain fullnodes, and > any mainchain fullnode can judge the validity of any WT from any sidechain > without a miner voting period. > > Side-to-side pegs are a generalization of main-to-side and side-to-main > pegs. A sidechain can simply implement OP_WITHDRAWPROOFVERIFY and allow > free lockboxes, and that is sufficient for the sidechain to support > imports of bitcoin from mainchain and from any other sidechain. > > Side-to-side pegs seem to imply that all pegs must have the same bitcoin > value transferred. What that value must be, is something that may be > debated endlessly. > > A side-to-side peg is a cut-through of a side-to-main peg from > one sidechain into a main-to-side peg into another sidechain. If a > withdrawal from side-to-main peg would be accepted by mainchain, then > another sidechain could, in principle, accept a proof that would > authorize a side-to-main peg directly as a side-to-side peg. > > Side-to-side pegs make attacks on sidechains more lucrative, as it > becomes possible to print sidecoins by successfully attacking a > different sidechain. > > Drivechain cannot implement side-to-side pegs, as WT validity is > voted on by mainchain miners, and asking mainchain miners about > side-to-side pegs requires mainchain miners to be aware of both > sidechains. Sidechain-headers-on-mainchain publishes SPV proofs > continuously to the mainchain, and since any sidechain fullnode is > also a mainchain fullnode (since sidechains are mergemined), then > every sidechain fullnode is automatically capable of accessing > and verifying SPV proofs for every other sidechain. > > However, the pegging here seems less flexible than the pegging > supported by drivechain. Drivechain lets pegs be any size, with > miner voting being the basis of knowing how much money is owned > by whom. > > Regards, > ZmnSCPxj > --94eb2c05d7c483e5bc0558b33941 Content-Type: text/html; charset="UTF-8" Content-Transfer-Encoding: quoted-printable
Hi ZmnSCPxj,

However, a lockbox on one chain is a WT on the other
ch= ain.=C2=A0 We can create a free lockbox on Ess, then use that lockbox as
a WT on Tee, inflating TeeCoin.

I= 9;m not sure if I follow what you are saying here. What do you mean by '= ;free lockbox'? I was assuming that I created an arbitrary blockchain, = say ChrisChain, that is NOT pegged to the bitcoin blockchain? I.e. the toke= ns on ChrisChain are worthless. Then I create a lockbox on ChrisChain with = my worthless tokens and attempt to transfer them into TeeCoin's chain? = However this doesn't make sense with


However, this = parameter is used to determine if it is a WT.=C2=A0 Sidechain
consensus should require that freely-created lockboxes set this
<= div>parameter to 0, so that a side block that creates free lockboxes where<= br>
this parameter is non-zero is an invalid side block.=C2=A0 Th= en a sidechain
will only treat a lockbox on another chain as = a WT if the wtFlag
parameter is nonzero.=C2=A0 This way, free= ly-created lockboxes are not
valid WT.=C2=A0 Valid WT must lo= ck actual, already unlocked coins, not
create new locked coins.

because I could arbitrarily set this p= arameter to 0. It seems that a sidechain upon inception should pay all of i= t's tokens to a single UTXO and prevent minting of coins after that. I&= #39;m fairly certain this is what elements does in it's genesis block. =

The is unrelated to the problem above, but it= will be a problem in sidchain-headers-on-mainchain if we have a limited am= ount of mining slots in the coinbase_tx output vector.

<= /div>
Let us assume we have a fixed set of sidechain slots in the coinb= ase output vector, in this case 10. However there are 15 competing sidechai= ns for these 10 slots. It may be possible for sidechains (say 15 sidechains= ) to compete indefinitely for these 10 slots -- causing indefinite forks. L= et us say sidechain 10 and sidechain 11 alternate block hashes in coinbase_= tx.vout[10] output. This means that a WT^ will never be considered valid be= cause it will appear to mainchain miners that there are competing forks of = the SAME sidechain, when in reality it is two unique sidechains competing t= o mine the the limited coinbase output vector space.

-Chris

On Fri, Sep 8, 2017 at 9:56 AM, ZmnSCPxj <= ;ZmnSCPxj@prot= onmail.com> wrote:
Goo= d morning,

Chris mentioned the use of OP_WITHD= RAWPROOFVERIFY.=C2=A0 I've come to realize
that this is a= ctually superior to use OP_WITHDRAWPROOFVERIFY with a
sidecha= in-headers-on-mainchain approach.

Briefly, a p= ayment to OP_WITHDRAWPROOFVERIFY is an instruction to transfer
value from the mainchain to a sidechain.=C2=A0 Thus, a payment to
OP_WITHDRAWPROOFVERIFY includes the sidechain to pay to, and a commi= tment
to a sidechain address (or whatever is the equivalent t= o a sidechain
address).

Various = OP_WITHDRAWPROOFVERIFY explanations exist.=C2=A0 Most of them include
OP_REORGPROOFVERIFY.=C2=A0 With sidechain-headers-on-mainchai= n, however, there is
no need for reorg proofs.=C2=A0 This is = because, the mainchain can see, in real
time, which branch of= the sidechain is getting extended.=C2=A0 Thus if someone
att= empts to defraud a sidechain by forking the sidechain to an invalid
state, sidechainers can immediately detect this on the mainchain and=
immediately act to prevent the invalid fork from being advan= ced.=C2=A0 After
all, a reorg proof is really just an SPV pro= of that is longer than some
previous SPV proof, that shows th= at the previous SPV proof is incorrect,
by showing that the b= lock at the specified height of the WT is not present
on a lo= nger SPV proof.

Since sidechain-headers-on-mai= nchain implies merge mining of sidechains,
with no option to = have independent proof-of-work of sidechains, the
sidechain&#= 39;s entire history is recorded on the mainchain, visible to all
<= div>mainchain nodes.

--

An advantage of sidechain-headers-on-mainchain is a side-to-side peg= without
passing through the mainchain.
That is= , a 2-way peg between any two chains, whether side or main.
<= br>
Sidechains supporting side-to-side transfer would require sup= porting
OP_WITHDRAWPROOFVERIFY, but not any of the other part= s of sidechains.

We must consider a WT format = (withdrawal transaction) that is compatible
with an OP_WITHDR= AWPROOFVERIFY Bitcoin transaction.

***That is,= a lockbox UTXO on one chain is a WT on another chain.***
Sidechains need not follow the mainchain format for its normal<= br>
transactions, only for WT transactions that move coins across= chains.

For this, mainchain should also have = its own "sidechain ID".=C2=A0 Perhaps a
sidechain I= D of 0 would be appropriate for mainchain, as its status as
m= ainchain.

Suppose we have two sidechains, Ess = and Tee, both of which support
side-to-side pegs.

An Ess fullnode is a Bitcoin fullnode, but an Ess fullnod= e is not
necessarily a Tee fullnode, and vice versa.

A lockbox redemption in sidechain-headers-on-mainchain= is simply a spend of
a lockbox, pointing to the sidechain he= ader containing WT, the merkle tree
path to the WT transactio= n from the h* commitment of the header, the output
which lock= s, and so on as per usual OP_WITHDRAWPROOFVERIFY.

<= div>Then a sidechain can create tokens from nothing, that are locked in a
OP_WITHDRAWPROOFVERIFY lockbox; this is the only way to create= sidecoin.
When transferring into a sidechain from mainchain,= or anywhere, the
sidechain either creates tokens locked into= OP_WITHDRAWPROOFVERIFY, or
looks for an existing UTXO with O= P_WITHDRAWPROOFVERIFY from the source
chain and spends them (= the latter is preferred as it is fewer
transactions and less = space on the sideblock, reducing sidechain fees).

<= div>OP_WITHDRAWPROOFVERIFY on a sidechain would query the mainchain fullnod= es.
Whatever rules allow lockbox unlocking on mainchain, will= also be the same
rules that allow lockbox unlocking on sidec= hains.
A mainchain RPC can even be made to simplify sidechain= verification of
side-to-side pegs, and to ensure that sidech= ains follow the same consensus
rules for OP_WITHDRAWPROOFVERI= FY.

So if we want transfer TeeCoin to EssCoin,= we spend into a
OP_WITHDRAWPROOFVERIFY lockbox on Teechain p= ointing to Esschain (i.e. a
Tee->Ess lockbox).=C2=A0 This = lockbox is itself a WT from the point of view of
Esschain.=C2= =A0 On Esschain, we look for an existing Ess->Tee lockbox, or
<= div>create a Ess->Tee lockbox of our own for a EssCoin fee.=C2=A0 Then w= e create a
spend of the Ess->Tee lockbox on Esschain, wait= until spending is
possible, and then post that transaction o= n Esschain.

Again, with sidechain-headers-on-<= wbr>mainchain, reorg proofs are unnecessary,
since any invali= d chain should be quickly buried by a valid chain,
unless the= economic majority decides that a sidechain is not worth
prot= ecting.

--

All is= not well, however.=C2=A0 Remember, on a sidechain, we can create new
sidecoin for free, provided they are in a lockbox.=C2=A0 Unlocking= that
lockbox would require a valid WT on the chain that the = lockbox is
dedicated to.=C2=A0 However, a lockbox on one chai= n is a WT on the other
chain.=C2=A0 We can create a free lock= box on Ess, then use that lockbox as
a WT on Tee, inflating T= eeCoin.

Instead, we add an additional paramete= r, wtFlag, to
OP_WITHDRAWPROOFVERIFY.
This para= meter is ignored by OP_WITHDRAWPROOFVERIFY opcode.

=
However, this parameter is used to determine if it is a WT.=C2=A0 Side= chain
consensus should require that freely-created lockboxes = set this
parameter to 0, so that a side block that creates fr= ee lockboxes where
this parameter is non-zero is an invalid s= ide block.=C2=A0 Then a sidechain
will only treat a lockbox o= n another chain as a WT if the wtFlag
parameter is nonzero.= =C2=A0 This way, freely-created lockboxes are not
valid WT.= =C2=A0 Valid WT must lock actual, already unlocked coins, not
create new locked coins.

On Bitcoin, of cours= e, this parameter must always be nonzero, since
freely-create= d lockboxes are not allowed on mainchain, as asset
issuance o= n mainchain is already fixed.

--

Let us now flesh out how WT and lockboxes look like.=C2=A0 = As we mentioned, a
lockbox on one chain is a WT on the destin= ation chain.=C2=A0 Or to be more
precise, what a destination = chain sees as a WT, is a lockbox on the source
chain.

Thus, a lockbox is a Bitcoin-formatted transaction ou= tput paying to the
scriptPubKey:

=C2=A0 <sidechain address commitment> <sidechain ID> OP_WITHDR= AWPROOFVERIFY

(assuming a softfork, additional= OP_DROP operations may occur after
OP_WITHDRAWPROOFVERIFY)

Suppose the above lockbox is paid to in the Bit= coin mainchain, with the
sidechain ID being the ID of Esschai= n.=C2=A0 This is itself a WT transaction
from the point of vi= ew of Esschain, on the principle that a lockbox on
one chain = is a WT on another chain.

Assuming Esschain is= a brand-new sidechain, it has no EssCoins yet.=C2=A0 The
sid= echain allows the arbitrary creation of sidecoin provided the new
=
sidecoins are in a lockbox whose sidechain address commitment is 0.=C2= =A0 So
in Esschain, we create the same coins on a UTXO paying= to the
scriptPubKey:

=C2=A0 0 0= OP_WITHDRAWPROOFVERIFY

The first 0 is the sid= echain address commitment, which is 0 since this
output was n= ot created by transferring to a sidechain; we
reuse the sidec= hain address commitment as the wtFlag.=C2=A0 The
second 0 is = the mainchain's ID.=C2=A0 The above is a lockbox from the point of
<= /div>
view of Esschain.=C2=A0 It is not a WT on mainchain, however, bec= ause the
sidechain address commitment is 0, which we use also= as the wtFlag
parameter.

Now, h= ow does a main-to-side peg work?=C2=A0 After creating the above output on
Esschain, we now spend the output with the below scriptSig:

=C2=A0 <mainchain output ID> <mainchain= WT transaction> <merkle path to WT transaction> <mainchain blo= ck hash>

On Esschain, OP_WITHDRAWPROOFVERIF= Y then verifies that the mainchain block
hash is a valid past= block of the mainchain, then locates the mainchain
header.= =C2=A0 It then checks the merkle tree path to the mainchain WT
transaction,
confirming that the mainchain contains that tr= ansaction, and confirms that
the
indicated outp= ut is in fact, a payment to an OP_WITHDRAWPROOFVERIFY, which
= pushes the Esschain ID, and with a nonzero sidechain address commitment.

(Esschain also needs to ensure that a single WT = is not used to unlock
multiple lockboxes on Esschain; the eas= iest way is to add it to a set,
but this set cannot be pruned= ; other ways of ensuring only a WT is only
used to unlock onc= e might be designed)

On Esschain, the sidechai= n does one final check: the transaction that spends
an OP_WIT= HDRAWPROOFVERIFY must have an output that pays to the sidechain
address committed to, and that output's value must be the same as th= e value
locked in the mainchain.

(for now, I think all lockboxes must have the same fixed amount, for
simplicity)

Now suppose we want to co= nvert back our EssCoin to Bitcoin.=C2=A0 We create a
lockbox = on Esschain, paying to the below:

=C2=A0 <b= itcoin P2SH address> 0 OP_WITHDRAWPROOFVERIFY

The bitcoin P2SH address is mainchain address commitment; for simplicity=
we just use P2SH on mainchain as it can encode any address.= =C2=A0 The 0 is the
mainchain ID.=C2=A0 The above Esschain lo= ckbox is itself a WT from Esschain to
mainchain.

Then, we look for an unspent lockbox on Esschain whose sid= echain ID is the
Esschain ID.=C2=A0 Note that we can select a= ny lockbox with the correct
sidechain ID, regardless of the s= idechain address commitment it may have.

Locat= ing an appropriate mainchain lockbox for Esschain coins, we then
<= div>provide the below scriptSig, paying out to the bitcoin P2SH address we<= br>
selected:

=C2=A0 <esschain ou= tput ID> <esschain WT tx> <merkle path to WT tx> <esschai= n block header hash>

On mainchain, we check= that the indicated sidechain block header hash is a
block he= ader on the longest chain of Esschain.=C2=A0 We check it has sufficient
=
depth.=C2=A0 Then we check if the merkle path to the WT tx is co= rrect and goes
to esschain WT tx.=C2=A0 Finally, we check the= indicated output ID, and check that
it is indeed an Esschain= lockbox dedicated to mainchain.=C2=A0 Finally, we check
that= the transaction has an output that spends the lockbox amount to the
specified bitcoin P2SH address.

(simil= arly mainchain nees to ensure that the Esschain WT is only used
once)

The key insight here is that side-to-= side pegs are just like side-to-main
pegs.=C2=A0 Suppose inst= ead we want to transfer our coins from Esscoin to
Teecoin.=C2= =A0 We would instead pay to the following lockbox on Esschain:

=C2=A0 <teecoin address commitment> <teechain ID&= gt; OP_WITHDRAWPROOFVERIFY

Then a Teechain tra= nsaction spending some Tee->Ess lockbox (or a fresh
lockbo= x if there are no Tee->Ess lockboxes on Teechain) is created.
<= div>We proceed as if it were a side-to-main peg, except it is a peg to
<= /div>
Teechain, either creating or unlocking TeeCoins.=C2=A0 Indeed, ma= inchain
fullnodes may even provide an RPC for checking OP_WIT= HDRAWPROOFVERIFY,
so as to reduce risk that a sidechain break= s consensus due to buggy
code.

-= -

All is still not well with side-to-side pegs= , however.

Suppose the economic majority decid= es that Esschain must die.=C2=A0 Perhaps it
has some irrecove= rable security bug, perhaps it adds features that allow
Essch= ain fullnodes to kill baby seals, perhaps a successful theft of
Esschain lockboxes was performed and Esscoins are now functionally
worthless.=C2=A0 Killing a sidechain is done by bribing miners to = put invalid
values into h*, and thus stealing Bitcoin->Ess= lockboxes.

If Esschain dies, however, and the= economic majority is not prepared to keep
Esschain dead, it = is possible to unlock Tee->Ess lockboxes on Teechain.
Unlo= cking existing Tee->Ess lockboxes on Teechain is safe, since they
represent coins that were locked into Bitcoin->Tee lockboxes.=C2= =A0 However,
it is still possible to create "free" = Tee->Ess lockboxes on Teechain, then
provide an invalid Te= e->Ess WT lockbox on the now-moribund Esschain to
unlock t= he free Tee->Ess lockbox on Teechain, inflating TeeCoin value.
=
Thus in the presence of side-to-side pegs, the death of even one sidec= hain
represents the death of every other sidechain!
=

Thus, to properly kill Esschain, the economic majority = should spam the
Esschain headers slot with a fixed value, say= 0, forever.=C2=A0 This makes it
very difficult to create a T= ee->Ess WT lockbox on Esschain, as you would
now be able t= o reverse a one-way hash function.

Alternative= ly, Teechain can softfork so that Tee->Ess lockboxes are no
longer creatable or spendable.=C2=A0 However, the death of Esschain requi= res
that all other sidechains, including Youchain, Veechain, = Dubyachain, and
so on, to softfork similarly.
<= br>
Perhaps both can be done: first the economic majority wanting= to kill
Esschain starts spamming it with invalid spends of B= itcoin->Ess lockboxes,
then when all Bitcoin->Ess lockb= oxes have been stolen, spam it with 0s
until all other sidech= ains have banned free Ess lockboxes on their chains.
Then, th= e economic majority can leave Esschain dead, and a later softfork
=
of mainchain prevents Esschain from being extended and allows mainchai= n
fullnodes to prune Esschain headers.

--

Thieves will still have the same dif= ficulty stealing from sidechains, but
now their payoff is inc= reased.=C2=A0 If a thief wants to steal Esschain
lockboxes, t= hen it is possible to pack an invalid Esschain block full of
= invalid WT to other chains.=C2=A0 Even chains that don't have lockboxes= to
Esschain can create lockboxes to Esschain for free.=C2=A0= Thus, instead of
stealing only one lockbox at a time on main= chain, the thief can steal one
lockbox on mainchain, and on e= very sidechain that supports side-to-side
pegs, at a time.=C2= =A0 The risk/reward ratio may shift drastically in that case.

However, this does mean that users of one chain must pay at= tention to
attacks on other chains, not just the chain they u= se.=C2=A0 If Teechain has no
side-to-side pegs, then Teechain= users will not care if Esschain is under
attack.=C2=A0 But i= f side-to-side pegs are allowed on Teechain, then Teechain
us= ers must also care about Esschain's health, as well as the health of
every other sidechain in existence.=C2=A0 Mainchain is protecte= d since free
lockboxes are not creatable on mainchain.=C2=A0 = Each sidechain is not; thus
the user of any sidechain must al= so stand by users of every other
sidechain, or else they all = fall apart.=C2=A0 Of course, this could more
simply lead to &= quot;I will not use Teechain even if it would be useful to me,
because if I use Teechain, I have to care about Esschain and Youchain and=
whatever."

--

Side-to-side pegs are useful to allow better liquidity and= provide
arbitrage quickly between sidechains, without having= to pass through
mainchain.=C2=A0 Otherwise, Esscoin may be v= alued slightly lower than Bitcoin,
then Teecoin valued slight= ly higher than Bitcoin, creating a larger
difference between = Esscoin and Teecoin values than what a full
side-to-side peg = could support.=C2=A0 2-way pegs from mainchain
to sidechain s= tabilize sidecoin with respect to maincoin.=C2=A0 Side-to-side
pegs stabilize all sidecoins to all other sidecoins.

Side-to-side pegs are enabled implicitly by sidechain-headers-on-<= wbr>mainchain,
as all sidechain fullnodes must necessarily be= mainchain fullnodes, and
any mainchain fullnode can judge th= e validity of any WT from any sidechain
without a miner votin= g period.

Side-to-side pegs are a generalizati= on of main-to-side and side-to-main
pegs.=C2=A0 A sidechain c= an simply implement OP_WITHDRAWPROOFVERIFY and allow
free loc= kboxes, and that is sufficient for the sidechain to support
i= mports of bitcoin from mainchain and from any other sidechain.

Side-to-side pegs seem to imply that all pegs must have th= e same bitcoin
value transferred.=C2=A0 What that value must = be, is something that may be
debated endlessly.

A side-to-side peg is a cut-through of a side-to-main peg f= rom
one sidechain into a main-to-side peg into another sidech= ain.=C2=A0 If a
withdrawal from side-to-main peg would be acc= epted by mainchain, then
another sidechain could, in principl= e, accept a proof that would
authorize a side-to-main peg dir= ectly as a side-to-side peg.

Side-to-side pegs= make attacks on sidechains more lucrative, as it
becomes pos= sible to print sidecoins by successfully attacking a
differen= t sidechain.

Drivechain cannot implement side-= to-side pegs, as WT validity is
voted on by mainchain miners,= and asking mainchain miners about
side-to-side pegs requires= mainchain miners to be aware of both
sidechains.=C2=A0 Sidec= hain-headers-on-mainchain publishes SPV proofs
continuously t= o the mainchain, and since any sidechain fullnode is
also a m= ainchain fullnode (since sidechains are mergemined), then
eve= ry sidechain fullnode is automatically capable of accessing
a= nd verifying SPV proofs for every other sidechain.

=
However, the pegging here seems less flexible than the pegging
supported by drivechain.=C2=A0 Drivechain lets pegs be any size, wit= h
miner voting being the basis of knowing how much money is o= wned
by whom.

Regards,
=
ZmnSCPxj

--94eb2c05d7c483e5bc0558b33941--