Return-Path: Received: from smtp2.osuosl.org (smtp2.osuosl.org [IPv6:2605:bc80:3010::133]) by lists.linuxfoundation.org (Postfix) with ESMTP id 521AAC002F for ; Wed, 19 Jan 2022 02:25:07 +0000 (UTC) Received: from localhost (localhost [127.0.0.1]) by smtp2.osuosl.org (Postfix) with ESMTP id 392A540180 for ; Wed, 19 Jan 2022 02:25:07 +0000 (UTC) X-Virus-Scanned: amavisd-new at osuosl.org X-Spam-Flag: NO X-Spam-Score: -2.098 X-Spam-Level: X-Spam-Status: No, score=-2.098 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, FREEMAIL_FROM=0.001, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001] autolearn=ham autolearn_force=no Authentication-Results: smtp2.osuosl.org (amavisd-new); dkim=pass (2048-bit key) header.d=gmail.com Received: from smtp2.osuosl.org ([127.0.0.1]) by localhost (smtp2.osuosl.org [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id qKQ2PXerxSCK for ; Wed, 19 Jan 2022 02:25:05 +0000 (UTC) X-Greylist: whitelisted by SQLgrey-1.8.0 Received: from mail-ed1-x532.google.com (mail-ed1-x532.google.com [IPv6:2a00:1450:4864:20::532]) by smtp2.osuosl.org (Postfix) with ESMTPS id 6F80D40159 for ; Wed, 19 Jan 2022 02:25:05 +0000 (UTC) Received: by mail-ed1-x532.google.com with SMTP id c71so4089514edf.6 for ; Tue, 18 Jan 2022 18:25:05 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=WrX23HsOCosOSc0UDoiNpRamHJDpiOeJ2ZFg/sfgBaw=; b=XAqW03O9fwgpJycMw1k9o2+Ki4UjMCagJrXrxklW7tTCCcSpCpYwQOPFQi4p27xb8z TND43IoAVW7FfVb+8vQmBep66XV4Zsa93IzyT7JnkdTX/LHsl4oM48FGI37gwMa7Iaw4 liCeHzICvTXccT9H0xA1ZG1WBD3pK1w1Sa1VeqyolhhAjozU0BE++9WfsaThD78yGsTJ 4cpOgqR6yut3DVGf0KrPEtLFv8MSrIUrN75Gm05OnTPANrC7wY0IyEfgL7rnVaGW84ME +WFXV0wqwS6/NEjaL7mdDQM92LnH3hr0yrMo9k6QO9hUUccCu+lS5Wvej1MmqMqr3qSr RrUA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=WrX23HsOCosOSc0UDoiNpRamHJDpiOeJ2ZFg/sfgBaw=; b=niKRUavDSENBScz+wKaYHZD+lbnohXrkaq+xFOI9he8c7rYmQEGrQsAwivRSLdutEj YAac0F/88Qmh9+5p/PJQhArm+2Qk7Lsvg/c+Mmn0Xk37MSLjyj66wYEjfNgChU/sBCv+ scGZ7k/YGfIsXqOyamlHhCfYfSiVe/P3sFJzrBFGnSwPq7yb3dOgN9WYPnFS+nSjOG/5 6lFO0odPbqR0k5xJqmPVVyzu4hk2E60jPY8c2+139v2dfB+dqrT34yuF8eOM8Mu2L27k 9qeV4m6qviukZrKX5rIchOhlQFjf6CTPMuZByu9s6wYf5Uxjj4Zm8oIq5a3UpxOs21gm p/HA== X-Gm-Message-State: AOAM530lwcu2AUSolrj5gvvrsyvUo7LoBLgDr7bwfXLbUheFxTjK65Yz 9zgQWbTtJbePrdGIMBXs4oLgitGFYtz7lyOLAAmZWqIslIo= X-Google-Smtp-Source: ABdhPJzYX4rALQI68MlLswdYazngtXX2iY+9jwpJtfbwsNDbT9HjgkhGvF6/bIR71aXwqfCrUeNv+sUC1dVUKxEbYto= X-Received: by 2002:a05:6402:350b:: with SMTP id b11mr28363136edd.355.1642559103564; Tue, 18 Jan 2022 18:25:03 -0800 (PST) MIME-Version: 1.0 References: In-Reply-To: From: Billy Tetrud Date: Tue, 18 Jan 2022 20:24:47 -0600 Message-ID: To: Bram Cohen Content-Type: multipart/alternative; boundary="000000000000e400fc05d5e617a3" X-Mailman-Approved-At: Wed, 19 Jan 2022 09:11:26 +0000 Cc: Bitcoin Protocol Discussion Subject: Re: [bitcoin-dev] Covenants and capabilities in the UTXO model X-BeenThere: bitcoin-dev@lists.linuxfoundation.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: Bitcoin Protocol Discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 19 Jan 2022 02:25:07 -0000 --000000000000e400fc05d5e617a3 Content-Type: text/plain; charset="UTF-8" > 'assert that my parent has a scriptpubkey of X'... That way you can, for example, have a UTXO which only allows itself to be absorbed by a transaction also involving a UTXO with a particular capability I'm not sure I fully follow. I usually think about covenants as having the reverse form, that a parent would assert "my children must have a script of the form XYZ". Are you saying you want to be able to specify that a UTXO can only be spent if the resulting outputs of that transaction all share the same script? I see this page but i don't understand how those concepts relate to covenants. > allow references to old blocks so code snippets can be pulled out of them Nodes currently aren't required to keep around the whole blockchain, but your proposal sounds like it would require them to. I think this could be pretty detrimental to future scalability. Monero, for example, has a situation where its UTXO set is the whole blockchain because you can't generally know what has been spent and what hasn't been. Allowing references to old blocks would pull in all this old block data into the UTXO set. So unless you're very careful about how or when you can reference old blocks, this could cause issues. > If the recipient can't parse a UTXO the defined behavior should be that they assume it's bricked. I must have misunderstood you. I think that's the appropriate response: if you don't know everything about how a UTXO sent "to you" can be spent, you can't really treat it as yours. On Tue, Jan 18, 2022 at 11:16 AM Bram Cohen wrote: > On Tue, Jan 18, 2022 at 7:10 AM Billy Tetrud > wrote: > >> > Since scriptpubkeys/scriptsigs continue to run ephemerally at >> validation time full turing completeness is much less dangerous than people >> fear. >> >> The covenant proposals I've seen that might give bitcoin turing >> completeness require a turing complete process to be stepped such that each >> step is a transaction paid for with a usual fee. This fact I think makes >> the turing completeness a lot less scary. No single transaction would be >> turing complete, while a sequence of them could be. But importantly, each >> transaction has a strictly limited runtime and every script could continue >> to have a calculable number of maximum runtime steps. >> > > This flows naturally out of the UTXO model. In ETH you don't know how much > transactions will cost in advance because things don't declare their state > up front, but with all dependencies declared up front execution can be made > completely deterministic. > > > It would also probably be a good idea to add in a bunch of special > purpose opcodes for making coherent statements about transactions since in > Bitcoin they're a very complex and hard to parse format. > >> >> What are some examples you're thinking of? >> > > What's needed from a programming perspective is the ability to say 'assert > that my parent has a scriptpubkey of X'. That way you can, for example, > have a UTXO which only allows itself to be absorbed by a transaction also > involving a UTXO with a particular capability ('pay to singleton' is a term > for this) and that capability can be enforced by the scriptpubkey asserting > that either its parent is the originator of it or that its parent also has > the same type of scriptpubkey. This allows capabilities to be added without > gunking up on chain state with things other than UTXOs. > > > >> >> > Once you start implementing complex general purpose functionality it >> tends to get very expensive very fast and is likely impractical unless >> there's a way to compress or at least de-duplicate snippets of code which >> are repeated on chain. >> >> I like this idea. If there was a way to dedupe scripts in some way, it >> could save a lot of bandwidth which would help bitcoin scale better. One >> thing we could do is have a specific set of pre-ordained script snippets >> that are given a shorthand that's stored in the software and explicitly >> shouldn't be transmitted long-hand. That would help for very standard >> widespread things. We could even add in a consensus rule where short-handed >> scripts pay for their expanded vbytes, not the vbytes of the compressed >> version. This would mean the incentives wouldn't be changed by this >> approach. >> > > One approach is to allow references to old blocks so code snippets can be > pulled out of them. That avoids having to define the 'common sections' up > front. Charging for virtual vbytes unfortunately keeps smart functionality > very expensive and the point is to make it not so expensive. > > >> > For a payment to someone to come with a rider where they could accept >> it and think their system was working properly for a while until you >> exercised some kind of retroactive veto on new action or even clawback >> would obviously be unacceptable behavior. >> >> I definitely agree. A payment's covenant should be completely knowable to >> the recipient, and recipients shouldn't accept random covenants they >> haven't explicitly accepted on their own. >> >> > for payments to come with covenants but the recipient not even be able >> to parse them unless they're fully buying into that behavior is much more >> reasonable. >> >> The recipient not being able to parse them? Couldn't that result in >> exactly the situation above you said was not acceptable? The recipient must >> be able to know all the possibilities of the covenant or there might be >> some secret retroactive clawback in there waiting to bite them. >> > > Not sure what you're saying. If the recipient can't parse a UTXO the > defined behavior should be that they assume it's bricked. > --000000000000e400fc05d5e617a3 Content-Type: text/html; charset="UTF-8" Content-Transfer-Encoding: quoted-printable
> 'assert that my parent has a scriptpubkey of= X'... That way you can, for example, have a UTXO which only allows its= elf to be absorbed by a transaction also involving a UTXO with a particular= capability

I'm not sure I fully follow. I usu= ally think about covenants as having the reverse form, that a parent would = assert "my children must have a script of the form XYZ". Are you = saying you want to be able to specify that a UTXO can only be spent if the = resulting outputs of that transaction all share the same script? I see this page=C2=A0bu= t i don't understand how those concepts relate to covenants.
=
>=C2=A0 allow references to old blocks so code snippets can be pulled out of them
Nodes currently aren't required to keep around the wh= ole blockchain, but your proposal sounds like it would require them to. I t= hink this could be pretty detrimental=C2=A0to future scalability. Monero, f= or example, has a situation where its UTXO set is the whole blockchain beca= use you can't generally know what has been spent and what hasn't be= en. Allowing references to old blocks would pull in all this old block data= into the UTXO set. So unless you're very careful about how or when you= can reference old blocks, this could cause issues.=C2=A0

> If the recipient can't parse a UTXO the defined behavior s= hould be that they assume it's bricked.

I must= have misunderstood you. I think that's the appropriate response: if yo= u don't know everything about how a UTXO sent "to you" can be= spent, you can't really treat it as yours.=C2=A0

<= /div>
O= n Tue, Jan 18, 2022 at 11:16 AM Bram Cohen <bram@chia.net> wrote:
On Tue, Jan 18, 2022 at= 7:10 AM Billy Tetrud <billy.tetrud@gmail.com> wrote:
>=C2=A0 Since scriptpubkeys/scriptsigs=C2=A0continue to run ephemerally at validati= on time full turing completeness is much less dangerous than people fear.= =C2=A0

The covenant proposals I've seen that might g= ive bitcoin turing completeness require a turing complete process to be ste= pped such that each step is a transaction paid for with a usual fee. This f= act I think makes the turing completeness a lot less scary. No single trans= action would be turing complete, while a sequence of them could be. But imp= ortantly, each transaction has a strictly limited runtime and every script = could continue to have a calculable number of maximum runtime steps.
<= /div>

This flows naturally out of the UTXO = model. In ETH you don't know how much transactions will cost in advance= because things don't declare their state up front, but with all depend= encies declared up front execution can be made completely deterministic.

=C2=A0> It would also probably be a good idea to = add in a bunch of special purpose opcodes for making coherent statements ab= out transactions since in Bitcoin they're a very complex and hard to pa= rse format.

What are some examples you're thinking of?=

What's needed from a progr= amming perspective is the ability to say 'assert that my parent has a s= criptpubkey of X'. That way you can, for example, have a UTXO which onl= y allows itself to be absorbed by a transaction also involving a UTXO with = a particular capability ('pay to singleton' is a term for this) and= that capability can be enforced by the scriptpubkey asserting that either = its parent is the originator of it or that its parent also has the same typ= e of scriptpubkey. This allows capabilities to be added without gunking up = on chain state with things other than UTXOs.

=C2=A0

> Once you start implementing complex general purpose functional= ity it tends to get very expensive very fast and is likely impractical unle= ss there's a way to compress or at least de-duplicate=C2=A0snippets of = code which are repeated on chain.

I like this idea= . If there was a way to dedupe scripts in some way, it could save a lot of = bandwidth which would help bitcoin scale better. One thing we could do is h= ave a specific set of pre-ordained script snippets that are given a shortha= nd that's stored in the software and explicitly shouldn't be transm= itted long-hand. That would help for very standard widespread things. We co= uld even add in a consensus rule where short-handed scripts pay for their e= xpanded vbytes, not the vbytes of the compressed version. This would mean t= he incentives wouldn't be changed by this approach.=C2=A0

One approach is to allow references to old b= locks so code snippets can be pulled out of them. That avoids having to def= ine the 'common sections' up front. Charging for virtual vbytes unf= ortunately keeps smart functionality very expensive and the point is to mak= e it not so expensive.
=C2=A0
> For a payment to someone to = come with a rider where they could accept it and think their system was wor= king properly for a while until you exercised some kind of retroactive veto= on new action or even clawback would obviously be unacceptable behavior.

I definitely agree. A payment's covenant sh= ould be completely knowable to the recipient, and recipients shouldn't = accept random covenants they haven't explicitly accepted on their own.= =C2=A0

> for payments to come with covenants bu= t the recipient not even be able to parse them unless they're fully buy= ing into that behavior is much more reasonable.=C2=A0

<= div>The recipient not being able to parse them? Couldn't that result in= exactly the situation above you said was not acceptable? The recipient mus= t be able to know all the possibilities of the covenant or there might be s= ome secret retroactive clawback in there waiting to bite them.
<= /blockquote>

Not sure what you're saying. If the rec= ipient can't parse a UTXO the defined behavior should be that they assu= me it's bricked.
--000000000000e400fc05d5e617a3--