Anthony Towns [ARCHIVE] on Nostr: 📅 Original date posted:2019-05-08 📝 Original message:On Mon, May 06, 2019 at ...
📅 Original date posted:2019-05-08
📝 Original message:On Mon, May 06, 2019 at 08:17:09PM +0000, Luke Dashjr via bitcoin-dev wrote:
> Some way to sign an additional script (not committed to by the witness
> program) seems like it could be a trivial addition.
Aside: if you want to commit to something extra *with* the witness
program, you could use either an unsolvable tapleaf branch (eg, one
that uses OP_RETURN and also pushes the data you want to commit to),
or a p2c construction like:
Taproot: Q = P + H_TapTweak(P || S)*G
P2C: P = R + H_"myp2c"(R || Contract)*G
If you don't have any scripts for S, you could set S=["OP_RETURN"]
to ensure there are no scripts. Having either the TapTweak formula or
the H_myp2c hash should be enough to ensure that your contract can't
get maliciously reinterpreted as a valid tapscript, having both is just
belts and suspenders.
But to address your question: if you want to commit to something extra
at spending/signing time rather than when creating the address, then
that's what the annex should be useful for. eg as a simple example,
your annex might be:
0x50 [flag]
0x25 [entry size]
0x77 [annex entry id]
0x0008c618 [block height == 575000]
0x00000000000000000007df59824a0c86d1cc21b90eb25259dd2dba5170cea5f5
[block hash for block at 575000]
which would allow you to commit to a particular block hash, and there
could be a soft fork that added the restriction that such a commitment
invalidates the transaction if the block at the given height doesn't
match the provided hash.
You still need to the soft-fork to do the enforcing, but once you have
that, *every* existing taproot address automatically gets "upgraded"
to allow you to make the commitment, including via key path spends,
which seems pretty nice.
(That construction (ie size,id,data) lets you have multiple entries in
the annex reasonably efficiently)
Cheers,
aj
Published at
2023-06-07 18:18:01Event JSON
{
"id": "cc32c0aa735dbde30ad51757ee905a2ed5fe7005c091f1f74486d129c1da5d65",
"pubkey": "f0feda6ad58ea9f486e469f87b3b9996494363a26982b864667c5d8acb0542ab",
"created_at": 1686161881,
"kind": 1,
"tags": [
[
"e",
"529e6716629ef4dd1bd1d9c3d84f71d38c914b08c03dc5a4b202d3977e8e4410",
"",
"root"
],
[
"e",
"72154b35f328f126b59390a428585afda26fecfece4840bcac3e896eed2896ab",
"",
"reply"
],
[
"p",
"4505072744a9d3e490af9262bfe38e6ee5338a77177b565b6b37730b63a7b861"
]
],
"content": "📅 Original date posted:2019-05-08\n📝 Original message:On Mon, May 06, 2019 at 08:17:09PM +0000, Luke Dashjr via bitcoin-dev wrote:\n\u003e Some way to sign an additional script (not committed to by the witness \n\u003e program) seems like it could be a trivial addition.\n\nAside: if you want to commit to something extra *with* the witness\nprogram, you could use either an unsolvable tapleaf branch (eg, one\nthat uses OP_RETURN and also pushes the data you want to commit to),\nor a p2c construction like:\n\n Taproot: Q = P + H_TapTweak(P || S)*G\n\n P2C: P = R + H_\"myp2c\"(R || Contract)*G\n\nIf you don't have any scripts for S, you could set S=[\"OP_RETURN\"]\nto ensure there are no scripts. Having either the TapTweak formula or\nthe H_myp2c hash should be enough to ensure that your contract can't\nget maliciously reinterpreted as a valid tapscript, having both is just\nbelts and suspenders.\n\nBut to address your question: if you want to commit to something extra\nat spending/signing time rather than when creating the address, then\nthat's what the annex should be useful for. eg as a simple example,\nyour annex might be:\n\n 0x50 [flag]\n 0x25 [entry size]\n 0x77 [annex entry id]\n 0x0008c618 [block height == 575000]\n 0x00000000000000000007df59824a0c86d1cc21b90eb25259dd2dba5170cea5f5\n [block hash for block at 575000]\n\nwhich would allow you to commit to a particular block hash, and there\ncould be a soft fork that added the restriction that such a commitment\ninvalidates the transaction if the block at the given height doesn't\nmatch the provided hash.\n\nYou still need to the soft-fork to do the enforcing, but once you have\nthat, *every* existing taproot address automatically gets \"upgraded\"\nto allow you to make the commitment, including via key path spends,\nwhich seems pretty nice.\n\n(That construction (ie size,id,data) lets you have multiple entries in\nthe annex reasonably efficiently)\n\nCheers,\naj",
"sig": "c81289cecd7f902f95c752bd75ada347e5767ba8a1f5257db90866c1c947e3509e0649c0aae8335cd1e154774168c21906793e3d928e43c1c059cf78d70f3ca5"
}