Anthony Towns [ARCHIVE] on Nostr: 📅 Original date posted:2020-02-20 📝 Original message: On Thu, Feb 20, 2020 at ...
📅 Original date posted:2020-02-20
📝 Original message:
On Thu, Feb 20, 2020 at 03:42:39AM +0000, ZmnSCPxj wrote:
> A thought that arises here is, what happens if I have forwarded a payment, then the outgoing channel is dropped onchain and that peer disconnects from me?
>
> Since the onchain HTLC might have a timelock of, say, a few hundred blocks from now, the outgoing peer can claim it up until the timelock.
> If the peer does not claim it, I cannot claim it in my incoming as well.
> I also cannot safely fail my incoming, as the outgoing peer can still claim it until the timelock expires.
Suppose the channel state looks like:
Bob's balance: $150
Carol's balance: $500
Bob to Carol: $50, hash X, timelock +2016 blocks
The pre-signed close transaction will have already deducted maybe $1 in
fees, say 50c from each balance.
At 5% pa, that's $50*0.05*2/52, so about 10 cents worth of "holding"
fees, so that seems like it's worth just committing to up-front, ie:
Bob's balance: $149.60 (-.50+.10)
Carol's balance: $499.40 (-.50-.10)
Bob to Carol: $50, hash X, timelock +2016 blocks
Fees: $1
And that seems necessary anyway: if the channel does drop to the chain,
then the HTLC can't be cancelled, so if it never confirms, Bob will have
had to pay, say, 9.5c to Alice waiting for the timeout, and can then
immediately cancel the HTLC with Alice allowing it to finish unwinding.
So I think the idea would be not to accept a (rate, amount, timelock)
tuple for an incoming HTLC unless the rate*amount*timelock product
is substantially less than what you're putting towards the blockchain
fees anyway, as otherwise you've got bad incentives for the other guy to
drop to the chain.
Note the rate increases with number of hops, so if it's 1% pa per hop,
the 11th peer will be emitting 10% pa. I think that's probably okay,
because BTC's deflationary nature probably means you don't need to earn
much interest on it, and you can naturally choose the rate dynamically
based on how many HTLCs you currently have open and how much of your
channel funds are being used up by the HTLC?
Also, you'd presumably update your channel state every hundred blocks,
reducing the 10c by half a cent or so each time, so you could have your
risk reduce. Maybe there could be some way of bumping the timelock across
a HTLC path so that the risk is capped, but if the HTLC is still being
paid for it doesn't have to be cancelled?
Cheers,
aj
Published at
2023-06-09 12:58:57Event JSON
{
"id": "97be8ea28f35dc1a4c5026fda0756eff356bfe78c84add783d6471fa1319d86e",
"pubkey": "f0feda6ad58ea9f486e469f87b3b9996494363a26982b864667c5d8acb0542ab",
"created_at": 1686315537,
"kind": 1,
"tags": [
[
"e",
"45cf63b0d2d71c68e5ad79035b26c58f0d0a7f08c912c1e3fb49d13bc9edb573",
"",
"root"
],
[
"e",
"2c3bc33c57e2a751ac600e4c96a3b9842df6fea7b577bf2e59609fc140eb7ba4",
"",
"reply"
],
[
"p",
"4505072744a9d3e490af9262bfe38e6ee5338a77177b565b6b37730b63a7b861"
]
],
"content": "📅 Original date posted:2020-02-20\n📝 Original message:\nOn Thu, Feb 20, 2020 at 03:42:39AM +0000, ZmnSCPxj wrote:\n\u003e A thought that arises here is, what happens if I have forwarded a payment, then the outgoing channel is dropped onchain and that peer disconnects from me?\n\u003e \n\u003e Since the onchain HTLC might have a timelock of, say, a few hundred blocks from now, the outgoing peer can claim it up until the timelock.\n\u003e If the peer does not claim it, I cannot claim it in my incoming as well.\n\u003e I also cannot safely fail my incoming, as the outgoing peer can still claim it until the timelock expires.\n\nSuppose the channel state looks like:\n\n Bob's balance: $150\n Carol's balance: $500\n Bob to Carol: $50, hash X, timelock +2016 blocks\n\nThe pre-signed close transaction will have already deducted maybe $1 in\nfees, say 50c from each balance.\n\nAt 5% pa, that's $50*0.05*2/52, so about 10 cents worth of \"holding\"\nfees, so that seems like it's worth just committing to up-front, ie:\n\n Bob's balance: $149.60 (-.50+.10)\n Carol's balance: $499.40 (-.50-.10)\n Bob to Carol: $50, hash X, timelock +2016 blocks\n Fees: $1\n\nAnd that seems necessary anyway: if the channel does drop to the chain,\nthen the HTLC can't be cancelled, so if it never confirms, Bob will have\nhad to pay, say, 9.5c to Alice waiting for the timeout, and can then\nimmediately cancel the HTLC with Alice allowing it to finish unwinding.\n\nSo I think the idea would be not to accept a (rate, amount, timelock)\ntuple for an incoming HTLC unless the rate*amount*timelock product\nis substantially less than what you're putting towards the blockchain\nfees anyway, as otherwise you've got bad incentives for the other guy to\ndrop to the chain.\n\nNote the rate increases with number of hops, so if it's 1% pa per hop,\nthe 11th peer will be emitting 10% pa. I think that's probably okay,\nbecause BTC's deflationary nature probably means you don't need to earn\nmuch interest on it, and you can naturally choose the rate dynamically\nbased on how many HTLCs you currently have open and how much of your\nchannel funds are being used up by the HTLC?\n\nAlso, you'd presumably update your channel state every hundred blocks,\nreducing the 10c by half a cent or so each time, so you could have your\nrisk reduce. Maybe there could be some way of bumping the timelock across\na HTLC path so that the risk is capped, but if the HTLC is still being\npaid for it doesn't have to be cancelled?\n\nCheers,\naj",
"sig": "f9384f9ba35a1644e0174ea1660b57ab29f4bfcf7bdeaee6a88155906bdfaaa9e10aa2b214dec0ebd2be28f451eb9fac7fafbb912527764a3b9af4721d7891b2"
}