Christian Decker [ARCHIVE] on Nostr: 📅 Original date posted:2019-02-22 📝 Original message: Rusty Russell <rusty at ...
📅 Original date posted:2019-02-22
📝 Original message:
Rusty Russell <rusty at rustcorp.com.au> writes:
> There are two ways to add TLV to the onion:
> 1. Leave the existing fields and put TLV in the padding:
> * [`8`:`short_channel_id`]
> * [`8`:`amt_to_forward`]
> * [`4`:`outgoing_cltv_value`]
> * [`12`:`padding`]
> 2. Replace existing fields with TLV (eg. 2=short_channel_id,
> 4=amt_to_forward, 6=outgoing_cltv_value) and use realm > 0
> to flag the new TLV format.
>
> The length turns out about the same for intermediary hops, since:
> TLV of short_channel_id => 10 bytes
> TLV of amt_to_forward => probably 5-6 bytes.
> TLV of outgoing_cltv_value => probably 3-4 bytes.
>
> For final hop, we don't use short_channel_id, so we save significantly
> there. That's also where many proposals to add information go (eg. a
> special "app-level" value), so it sways me in the direction of making
> TLV take the entire room.
I'd definitely vote for making the entire payload a TLV (option 2) since
that allows us to completely redefine the payload. I don't think the
overhead argument really applies since we're currently wasting 12 bytes
of payload anyway, and with option 2 we still fit the current payload in
a single frame.
There is however a third option, namely make the entire payload a
TLV-set and then use the old payload format (`short_channel_id`,
`amt_to_forward`, `outgoing_ctlv_value`) as a single TLV-value with 20
bytes of size. That means we have only 2 bytes of overhead compared to
the old v0 format (4 byte less than option 2), and can drop it if we
require some other payload that doesn't adhere to this format.
Cheers,
Christian
Published at
2023-06-09 12:54:19Event JSON
{
"id": "86cc60d09eedd4f979539fc68421a1b56196ed2984399f853520a97e07f68cd2",
"pubkey": "72cd40332ec782dd0a7f63acb03e3b6fdafa6d91bd1b6125cd8b7117a1bb8057",
"created_at": 1686315259,
"kind": 1,
"tags": [
[
"e",
"61dca50065a6b61d750bc7aab5174590056d9870f8b930ce2ae7ab6470716ff3",
"",
"root"
],
[
"e",
"2c90e1db10e42cb085d8fe4a9a7531958157ce378e0e31e4eda422ca731b6a00",
"",
"reply"
],
[
"p",
"13bd8c1c5e3b3508a07c92598647160b11ab0deef4c452098e223e443c1ca425"
]
],
"content": "📅 Original date posted:2019-02-22\n📝 Original message:\nRusty Russell \u003crusty at rustcorp.com.au\u003e writes:\n\u003e There are two ways to add TLV to the onion:\n\u003e 1. Leave the existing fields and put TLV in the padding:\n\u003e * [`8`:`short_channel_id`]\n\u003e * [`8`:`amt_to_forward`]\n\u003e * [`4`:`outgoing_cltv_value`]\n\u003e * [`12`:`padding`]\n\u003e 2. Replace existing fields with TLV (eg. 2=short_channel_id,\n\u003e 4=amt_to_forward, 6=outgoing_cltv_value) and use realm \u003e 0\n\u003e to flag the new TLV format.\n\u003e\n\u003e The length turns out about the same for intermediary hops, since:\n\u003e TLV of short_channel_id =\u003e 10 bytes\n\u003e TLV of amt_to_forward =\u003e probably 5-6 bytes.\n\u003e TLV of outgoing_cltv_value =\u003e probably 3-4 bytes.\n\u003e\n\u003e For final hop, we don't use short_channel_id, so we save significantly\n\u003e there. That's also where many proposals to add information go (eg. a\n\u003e special \"app-level\" value), so it sways me in the direction of making\n\u003e TLV take the entire room.\n\nI'd definitely vote for making the entire payload a TLV (option 2) since\nthat allows us to completely redefine the payload. I don't think the\noverhead argument really applies since we're currently wasting 12 bytes\nof payload anyway, and with option 2 we still fit the current payload in\na single frame.\n\nThere is however a third option, namely make the entire payload a\nTLV-set and then use the old payload format (`short_channel_id`,\n`amt_to_forward`, `outgoing_ctlv_value`) as a single TLV-value with 20\nbytes of size. That means we have only 2 bytes of overhead compared to\nthe old v0 format (4 byte less than option 2), and can drop it if we\nrequire some other payload that doesn't adhere to this format.\n\nCheers,\nChristian",
"sig": "b95259086037a873977f8038084512cbbb156c2d2186f2e9b4cb0ca3b3d523d15ab04719084aa5ffdeda7eeac793e2fd57b8bacd7783ecf1b2cedf77e9472135"
}