public inbox for bitcoindev@googlegroups.com
 help / color / mirror / Atom feed
* [bitcoindev] Covenants Support - Bitcoin Wiki
@ 2024-11-29 14:08 /dev /fd0
  2024-12-06 21:45 ` Jonas Nick
  0 siblings, 1 reply; 8+ messages in thread
From: /dev /fd0 @ 2024-11-29 14:08 UTC (permalink / raw)
  To: Bitcoin Development Mailing List


[-- Attachment #1.1: Type: text/plain, Size: 1292 bytes --]

Hi Bitcoin Developers,

I have created the first draft of a bitcoin wiki page to update opinions of 
bitcoin developers on different covenant proposals. It uses the same 
template as segwit support page. Feel free to add more opcodes as I only 
added the ones that looked relevant.

Wiki link: https://en.bitcoin.it/wiki/Covenants_support

I am aware of the opinions of some developers; however, I did not want to 
write on their behalf. Please add your GitHub username and share your 
opinions on the proposed opcodes. This would help in reaching a consensus 
on the next soft fork and make things easier.

Rationale for supporting OP_CTV: 
https://notes.dunst.be/slide/#/2/slide/view/Ekky-cAegV9dSOaNOjH9TStNOmAnrhDDc9hxHlmRs5M/embed/present/

I like a few other use cases however mainly interested in pools with 
covenants. This would help improve joinstr (coinjoin implementation).

/dev/fd0
floppy disk guy



-- 
You received this message because you are subscribed to the Google Groups "Bitcoin Development Mailing List" group.
To unsubscribe from this group and stop receiving emails from it, send an email to bitcoindev+unsubscribe@googlegroups•com.
To view this discussion visit https://groups.google.com/d/msgid/bitcoindev/028c0197-5c45-4929-83a9-cfe7c87d17f4n%40googlegroups.com.

[-- Attachment #1.2: Type: text/html, Size: 1859 bytes --]

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [bitcoindev] Covenants Support - Bitcoin Wiki
  2024-11-29 14:08 [bitcoindev] Covenants Support - Bitcoin Wiki /dev /fd0
@ 2024-12-06 21:45 ` Jonas Nick
  2024-12-07  0:29   ` /dev /fd0
  2024-12-09 20:13   ` Anthony Towns
  0 siblings, 2 replies; 8+ messages in thread
From: Jonas Nick @ 2024-12-06 21:45 UTC (permalink / raw)
  To: bitcoindev

Hi /dev/fd0,

I do not think the segwit support page serves as a suitable template for
building rough consensus, in general and for covenants in particular. It lacks
key characteristics that would help in (rough) consensus building as outlined in
RFC 7282 [0] (which I strongly recommend reading).

I propose the following changes:

1. Separate Technical Evaluation from Community Support

    The ratings "Deficient" and "Wanting" are supposed to be assigned when a
    proposal considered to have insufficient community support. This creates a
    circular problem: the wiki page is meant to help build community support, but
    the ratings already assume certain levels of support. This makes the ratings
    less useful and risks creating self-fulfilling prophecies.

    A simple solution would be to remove the "Wanting" and "Deficient"
    categories.

2. Require Stating Reasons for Objections

    As RFC 7282 states:

    > Remember, coming to consensus is a matter of eliminating disagreement.

    To achieve this, we need to clearly state objections to enable a meaningful
    discussion. Each "No" rating should include a link to a mailing list post or
    similar document that explicitly states the objection, covering aspects such
    as technical deficiencies, likelihood of widespread adoption, and impact on
    decentralization.

    > Then, the purported failings
    > of the choice can be examined by the working group.  The objector
    > might convince the rest of the group that the objections are valid
    > and the working group might choose a different path.  Conversely, the
    > working group might convince the objector that the concerns can be
    > addressed, or that the choice is simply unappealing (i.e., something
    > the objector can "live with") and not a show-stopper.

    Because there is no working group making decisions in Bitcoin,
    community members must individually assess whether proposals have achieved
    rough developer consensus.

    Developers giving positive technical evaluations are also encouraged to share
    their reasoning, as this can help inform others' assessments.

3. Add Links to BIP Drafts

    All opcodes mentioned on the wiki page presumably have corresponding draft
    BIPs. These should be linked to provide a clear basis for technical
    evaluation.

[0] https://datatracker.ietf.org/doc/html/rfc7282

-- 
You received this message because you are subscribed to the Google Groups "Bitcoin Development Mailing List" group.
To unsubscribe from this group and stop receiving emails from it, send an email to bitcoindev+unsubscribe@googlegroups•com.
To view this discussion visit https://groups.google.com/d/msgid/bitcoindev/941b8c22-0b2c-4734-af87-00f034d79e2e%40gmail.com.


^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [bitcoindev] Covenants Support - Bitcoin Wiki
  2024-12-06 21:45 ` Jonas Nick
@ 2024-12-07  0:29   ` /dev /fd0
  2024-12-07  1:42     ` Yuval Kogman
  2024-12-09 20:13   ` Anthony Towns
  1 sibling, 1 reply; 8+ messages in thread
From: /dev /fd0 @ 2024-12-07  0:29 UTC (permalink / raw)
  To: Bitcoin Development Mailing List


[-- Attachment #1.1: Type: text/plain, Size: 4479 bytes --]

Hi Jonas,

Thank you for reviewing the wiki page.

> 1. Separate Technical Evaluation from Community Support
> A simple solution would be to remove the "Wanting" and "Deficient"
categories.

There are 7 options available to share opinion on an opcode and only 2 
include community support. If a developer wants to ACK a proposal it is 
possible to use to 'prefer' or 'acceptable' and 'no' for NACK. 

We have already changed definition for 3 categories. I removed community 
support from 'no' and moonsettler rephrased 'prefer' and 'evaluating'. 
Removing some categories at this point breaks the whole table. 

At the end of the day bitcoin developers build for community so if someone 
wants to play safe and use 'deficient' and 'wanting', its their choice and 
I think we should allow such freedom to express themselves. 

>  2. Require Stating Reasons for Objections

A column for adding a link to rationale will be added this weekend. I had 
tweeted about it but forgot to update the mailing list thread.

>  Because there is no working group making decisions in Bitcoin,
> community members must individually assess whether proposals have achieved
> rough developer consensus.

>  Developers giving positive technical evaluations are also encouraged to 
share
> their reasoning, as this can help inform others' assessments.

I agree with you on this and I have requested everyone to respond to this 
thread.

>  3. Add Links to BIP Drafts

I have added the links to BIP drafts for all opcodes.

/dev/fd0
floppy disk guy

On Saturday, December 7, 2024 at 4:18:21 AM UTC+5:30 Jonas Nick wrote:

> Hi /dev/fd0,
>
> I do not think the segwit support page serves as a suitable template for
> building rough consensus, in general and for covenants in particular. It 
> lacks
> key characteristics that would help in (rough) consensus building as 
> outlined in
> RFC 7282 [0] (which I strongly recommend reading).
>
> I propose the following changes:
>
> 1. Separate Technical Evaluation from Community Support
>
> The ratings "Deficient" and "Wanting" are supposed to be assigned when a
> proposal considered to have insufficient community support. This creates a
> circular problem: the wiki page is meant to help build community support, 
> but
> the ratings already assume certain levels of support. This makes the 
> ratings
> less useful and risks creating self-fulfilling prophecies.
>
> A simple solution would be to remove the "Wanting" and "Deficient"
> categories.
>
> 2. Require Stating Reasons for Objections
>
> As RFC 7282 states:
>
> > Remember, coming to consensus is a matter of eliminating disagreement.
>
> To achieve this, we need to clearly state objections to enable a meaningful
> discussion. Each "No" rating should include a link to a mailing list post 
> or
> similar document that explicitly states the objection, covering aspects 
> such
> as technical deficiencies, likelihood of widespread adoption, and impact on
> decentralization.
>
> > Then, the purported failings
> > of the choice can be examined by the working group. The objector
> > might convince the rest of the group that the objections are valid
> > and the working group might choose a different path. Conversely, the
> > working group might convince the objector that the concerns can be
> > addressed, or that the choice is simply unappealing (i.e., something
> > the objector can "live with") and not a show-stopper.
>
> Because there is no working group making decisions in Bitcoin,
> community members must individually assess whether proposals have achieved
> rough developer consensus.
>
> Developers giving positive technical evaluations are also encouraged to 
> share
> their reasoning, as this can help inform others' assessments.
>
> 3. Add Links to BIP Drafts
>
> All opcodes mentioned on the wiki page presumably have corresponding draft
> BIPs. These should be linked to provide a clear basis for technical
> evaluation.
>
> [0] https://datatracker.ietf.org/doc/html/rfc7282
>

-- 
You received this message because you are subscribed to the Google Groups "Bitcoin Development Mailing List" group.
To unsubscribe from this group and stop receiving emails from it, send an email to bitcoindev+unsubscribe@googlegroups•com.
To view this discussion visit https://groups.google.com/d/msgid/bitcoindev/6d375199-834e-4630-8b5c-fcc5ed137cb1n%40googlegroups.com.

[-- Attachment #1.2: Type: text/html, Size: 5731 bytes --]

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [bitcoindev] Covenants Support - Bitcoin Wiki
  2024-12-07  0:29   ` /dev /fd0
@ 2024-12-07  1:42     ` Yuval Kogman
  0 siblings, 0 replies; 8+ messages in thread
From: Yuval Kogman @ 2024-12-07  1:42 UTC (permalink / raw)
  To: /dev /fd0; +Cc: Bitcoin Development Mailing List

On Sat, 7 Dec 2024 at 02:10, /dev /fd0 <alicexbtong@gmail•com> wrote:
>
> There are 7 options available to share opinion on an opcode and only 2 include community support. If a developer wants to ACK a proposal it is possible to use to 'prefer' or 'acceptable' and 'no' for NACK.

the 6 options (+ "evaluating", which is not in the space) represent
only a subset of the product of two independent dimensions:

- a given dev's (hopefully reasoned) opinion on the technical merit of
a proposal
- and their (speculative, vibes based) opinion about community support.

> At the end of the day bitcoin developers build for community so if someone wants to play safe and use 'deficient' and 'wanting', its their choice and I think we should allow such freedom to express themselves.

to allow that full freedom to express themselves 8 options seem
necessary, not counting "evaluating":

{ no, weak, acceptable, prefer } x { sufficient community support,
insufficient }

(or alternatively, { no, weak, acceptable } is the technical merit
dimension, and then "prefer" seems redundant?)

anyway, supposing all pairs of values were expressible, the latter is
confounded or arguably even ill defined see
https://en.wikipedia.org/wiki/Keynesian_beauty_contest (and this is
exacerbated by the fact that the two values are combined into a single
dimension, e.g. if i strongly prefer something but it lacks community
support), so to allow people to e.g. only express a technical opinion,
and abstain from speculating on community support, we'd want:

{ ⊥, weak, acceptable, prefer } x { ⊥, sufficient, insufficient }

(where evaluating = (⊥, ⊥))

finally, even if the full set of possibilities was expressible, and
assuming the infinite regress of speculating on others' opinions about
others opinions was not an issue, it would still not be totally
orderable, so the color scheme is arguably misleading

both the partial ordering and the speculative nature add a lot of
ambiguity, i.e. different answers are likely to mean different things
to different respondents and to people reading the table

-- 
You received this message because you are subscribed to the Google Groups "Bitcoin Development Mailing List" group.
To unsubscribe from this group and stop receiving emails from it, send an email to bitcoindev+unsubscribe@googlegroups•com.
To view this discussion visit https://groups.google.com/d/msgid/bitcoindev/CAAQdECALHHysr4PNRGXcFMCk5AjRDYgquUUUvuvwHGoeJDgZJA%40mail.gmail.com.


^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [bitcoindev] Covenants Support - Bitcoin Wiki
  2024-12-06 21:45 ` Jonas Nick
  2024-12-07  0:29   ` /dev /fd0
@ 2024-12-09 20:13   ` Anthony Towns
  2024-12-09 20:45     ` Brandon Black
  1 sibling, 1 reply; 8+ messages in thread
From: Anthony Towns @ 2024-12-09 20:13 UTC (permalink / raw)
  To: Jonas Nick; +Cc: bitcoindev

On Fri, Dec 06, 2024 at 09:45:31PM +0000, Jonas Nick wrote:
> I do not think the segwit support page serves as a suitable template for
> building rough consensus, in general and for covenants in particular.

The segwit page followed the example of the p2sh page [0]; I wasn't around
for that, but from the reporting it didn't sound like a particularly
clean result, with the result coming down to the proposers of BIP 16/17
respectively voting "No" and "Very weak" to the competition, and "No"
being worse than "Very weak". It's not a good example to follow.

[0] https://en.bitcoin.it/wiki/P2SH_Votes

The only polling question that's really necessary for establishing
that consensus exists is "have all my objections/concerns been
addressed? [yes/no]" (perhaps with a followup asking your top outstanding
concerns are). If the poll is widely open, and everyone's answer is
"yes"; that's consensus. (Even if some people's answers are "no"; it
might still be "rough" consensus, of course)

Personally, I find it hard to take any of this remotely seriously at this
point; the most recent example is reardencode's claim to have created
scripts for lightning-symmetry using either LNHANCE or CCV. This was
done via a tweet [1] and a gist [2], without any real exploration of
what the full transaction flow would look like. Did it have any chance of
working? Well, no, because it had an invented "3DROP" opcode instead of
"DROP 2DROP" or similar, just as if it were ChatGPT hallucinating what
a wallet script might look like. That would have failed as soon as it
had been run through any of the script test environments out there,
let alone through any actual node software, so it's clear that nobody
involved had done anything of the sort, even locally. If the proponents
aren't taking their proposals seriously, why on earth should anyone else?

[1] https://x.com/reardencode/status/1864749512113483993
[2] https://gist.github.com/reardencode/ae982ede45af12fe1ff7248fd6f1958c#file-ctv-csfs-vault-txt

Cheers,
aj

-- 
You received this message because you are subscribed to the Google Groups "Bitcoin Development Mailing List" group.
To unsubscribe from this group and stop receiving emails from it, send an email to bitcoindev+unsubscribe@googlegroups•com.
To view this discussion visit https://groups.google.com/d/msgid/bitcoindev/Z1dPfjDwioa/DXzp%40erisian.com.au.


^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [bitcoindev] Covenants Support - Bitcoin Wiki
  2024-12-09 20:13   ` Anthony Towns
@ 2024-12-09 20:45     ` Brandon Black
  2024-12-11 13:28       ` Anthony Towns
  0 siblings, 1 reply; 8+ messages in thread
From: Brandon Black @ 2024-12-09 20:45 UTC (permalink / raw)
  To: Anthony Towns; +Cc: Jonas Nick, bitcoindev

Hi AJ,

On 2024-12-10 (Tue) at 06:13:50 +1000, Anthony Towns wrote:
> Personally, I find it hard to take any of this remotely seriously at this
> point; the most recent example is reardencode's claim to have created
> scripts for lightning-symmetry using either LNHANCE or CCV. This was
> done via a tweet [1] and a gist [2], without any real exploration of
> what the full transaction flow would look like. Did it have any chance of
> working? Well, no, because it had an invented "3DROP" opcode instead of
> "DROP 2DROP" or similar, just as if it were ChatGPT hallucinating what
> a wallet script might look like. That would have failed as soon as it
> had been run through any of the script test environments out there,
> let alone through any actual node software, so it's clear that nobody
> involved had done anything of the sort, even locally. If the proponents
> aren't taking their proposals seriously, why on earth should anyone else?
> 
> [1] https://x.com/reardencode/status/1864749512113483993
> [2] https://gist.github.com/reardencode/ae982ede45af12fe1ff7248fd6f1958c#file-ctv-csfs-vault-txt

You've made two strange errors in your commentary here.

First, my example scripts for Lightning Symmetry all use opcodes that do
not exist in the script testing environments so I cannot run my scripts
through those environments. The point of the exercise is to demonstrate
how the potential opcodes can perform an example protocol and roughly
how the cost compares. The fact that I misglanced the opcode list
during drafting is completely irrelevant to the exercise.

Second, I am not a "proponent" of VAULT or CCV. I'm merely demonstrating
various ways that they can be used, as a service to those who are
discussing various options for upgrading bitcoin (as I strongly implied
in my post on X - I only wrote the script you found an error in because
of others' answers on Floppy's table).

In other words, it's hard to take your commentary seriously when you
don't bother to understand either the purpose and the context of what
you are commenting on.

Hope this clarifies.

All the best,

--Brandon

-- 
You received this message because you are subscribed to the Google Groups "Bitcoin Development Mailing List" group.
To unsubscribe from this group and stop receiving emails from it, send an email to bitcoindev+unsubscribe@googlegroups•com.
To view this discussion visit https://groups.google.com/d/msgid/bitcoindev/Z1dW77h3rhr5oivP%40console.


^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [bitcoindev] Covenants Support - Bitcoin Wiki
  2024-12-09 20:45     ` Brandon Black
@ 2024-12-11 13:28       ` Anthony Towns
  2024-12-11 15:11         ` Brandon Black
  0 siblings, 1 reply; 8+ messages in thread
From: Anthony Towns @ 2024-12-11 13:28 UTC (permalink / raw)
  To: Brandon Black; +Cc: bitcoindev

On Mon, Dec 09, 2024 at 12:45:35PM -0800, Brandon Black wrote:
> First, my example scripts for Lightning Symmetry all use opcodes that do
> not exist in the script testing environments so I cannot run my scripts
> through those environments.

You've implemented your code against bitcoin inquisition 27.x [0],
which already includes an "evalscript" subcommand [1] that allows you
to do precisely that, even without updating the functional test suite
so that CI passes. So, yes, you can run your scripts through testing
environments.

You can also easily tweak your scripts to run them through unmodified
testing environments to at least ensure you aren't making trivial errors
and to check the stack is working the way you think it should -- replace
the new commands with OP_NOP (for things like CTV) or OP_2DROP OP_VERIFY
(for things like CHECKSIGVERIFY, where an empty signature would fail,
and there are two other arguments to ignore).

> The fact that I misglanced the opcode list
> during drafting is completely irrelevant to the exercise.

That you made a mistake is perhaps excusable, though as someone proposing
to modify the script language, being more than glancingly familiar with
script as it is today seems like a pretty basic expectation. That you
didn't put your work through even the most basic testing cycle before
publicising it isn't so excusable. [2]

It's utterly astounding to me that you're publicising your project
as "lnhance" [3] and yet are willing to be that careless in your
demonstrations of how it might enhance the lightning network.

Cheers,
aj

[0] https://github.com/bitcoin-inquisition/bitcoin/pull/45
[1] https://github.com/bitcoin-inquisition/bitcoin/pull/58

[2] For instance, I made a claim above that you can use evalscript
    with your inquisition pr. That's something that I should test,
    and when I do, it turns out there's a line that needs fixing to
    make that work. Here's what it looks like after that's done,
    checking the first entry in the bip340 test vectors:

    ```
    $ ./bitcoin-util -sigversion=tapscript -script_flags=CHECKSIGFROMSTACK evalscript '0x200000000000000000000000000000000000000000000000000000000000000000 0x20F9308A019258C31049344F85F89D5229B531C845836F99B08601F113BCE036F9 CHECKSIGFROMSTACK' E907831F80848D1069A5371B402410364BDF1C5F8307B0084C55F1CE2DCA821525F66A4A85EA8B71E482A74F382D2CE5EBEEE8FDB2172F477DF4900D310536C0
    {
      "script": {
        "asm": "0000000000000000000000000000000000000000000000000000000000000000 f9308a019258c31049344f85f89d5229b531c845836f99b08601f113bce036f9 OP_CHECKSIGFROMSTACK",
        "hex": "20000000000000000000000000000000000000000000000000000000000000000020f9308a019258c31049344f85f89d5229b531c845836f99b08601f113bce036f9cc",
        "type": "nonstandard"
      },
      "sigversion": "tapscript",
      "script_flags": [
        "CHECKSIGFROMSTACK"
      ],
      "stack-after": [
        "01"
      ],
      "sigop-count": 0,
      "success": true
    }
    ```

[3] https://www.lnhance.org/#team

-- 
You received this message because you are subscribed to the Google Groups "Bitcoin Development Mailing List" group.
To unsubscribe from this group and stop receiving emails from it, send an email to bitcoindev+unsubscribe@googlegroups•com.
To view this discussion visit https://groups.google.com/d/msgid/bitcoindev/Z1mTiguyy5waz4Vg%40erisian.com.au.


^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [bitcoindev] Covenants Support - Bitcoin Wiki
  2024-12-11 13:28       ` Anthony Towns
@ 2024-12-11 15:11         ` Brandon Black
  0 siblings, 0 replies; 8+ messages in thread
From: Brandon Black @ 2024-12-11 15:11 UTC (permalink / raw)
  To: Anthony Towns; +Cc: bitcoindev

Hi AJ,

On 2024-12-11 (Wed) at 23:28:42 +1000, Anthony Towns wrote:
> On Mon, Dec 09, 2024 at 12:45:35PM -0800, Brandon Black wrote:
> > First, my example scripts for Lightning Symmetry all use opcodes that do
> > not exist in the script testing environments so I cannot run my scripts
> > through those environments.
> 
> You've implemented your code against bitcoin inquisition 27.x [0],
> which already includes an "evalscript" subcommand [1] that allows you
> to do precisely that, even without updating the functional test suite
> so that CI passes. So, yes, you can run your scripts through testing
> environments.

There seems to still be some confusion here. The script you found a bug
in was using OP_VAULT, which I haven't implemented and which is not in
inquisition.

> You can also easily tweak your scripts to run them through unmodified
> testing environments to at least ensure you aren't making trivial errors
> and to check the stack is working the way you think it should -- replace
> the new commands with OP_NOP (for things like CTV) or OP_2DROP OP_VERIFY
> (for things like CHECKSIGVERIFY, where an empty signature would fail,
> and there are two other arguments to ignore).
> 
> > The fact that I misglanced the opcode list
> > during drafting is completely irrelevant to the exercise.
> 
> That you made a mistake is perhaps excusable, though as someone proposing
> to modify the script language, being more than glancingly familiar with
> script as it is today seems like a pretty basic expectation. That you
> didn't put your work through even the most basic testing cycle before
> publicising it isn't so excusable. [2]

I must have been unclear in how I published my recent script hacking to
trigger this type of response. I did not say, "here are production ready
scripts that I've validated for securing your funds." I hacked up a
proof of concept to demonstrate conceptually how certain types of things
can be done using certain proposed opcodes. Why would I have run them
through a testing environment? Why would I have worried about whether
there's 3DROP or only 3DUP? Those are irrelevant to whether CCV or VAULT
can be used as part of a Lightning Symmetry implementation. Details that
can be worked out later.

I published my results and how I arrived at them (in the gist showing my
expected stack progression) and anyone can correct me (as you did).

> It's utterly astounding to me that you're publicising your project
> as "lnhance" [3] and yet are willing to be that careless in your
> demonstrations of how it might enhance the lightning network.

My work on demonstrating how opcodes unrelated to LNHANCE can also be
used for Lightning Symmetry is somehow related to my work on LNHANCE
how?

Did I do something to offend you?

Best,

--Brandon

-- 
You received this message because you are subscribed to the Google Groups "Bitcoin Development Mailing List" group.
To unsubscribe from this group and stop receiving emails from it, send an email to bitcoindev+unsubscribe@googlegroups•com.
To view this discussion visit https://groups.google.com/d/msgid/bitcoindev/Z1mrvy1wDcqxjXob%40console.


^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2024-12-11 15:22 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-11-29 14:08 [bitcoindev] Covenants Support - Bitcoin Wiki /dev /fd0
2024-12-06 21:45 ` Jonas Nick
2024-12-07  0:29   ` /dev /fd0
2024-12-07  1:42     ` Yuval Kogman
2024-12-09 20:13   ` Anthony Towns
2024-12-09 20:45     ` Brandon Black
2024-12-11 13:28       ` Anthony Towns
2024-12-11 15:11         ` Brandon Black

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox