[Lightning-dev] Backward deterministic R Value
nicolas.dorier at gmail.com
Mon Mar 7 12:35:30 UTC 2016
One way deterministic RValue Generation
My previous proposal, while saving space on chain, does not
solve the fact that we need to save offchain one signature per
I have another proposal, so you don't need any data to store for
Keep the actual HTLC/Payment channel contracts, but make
the "RValues" backward deterministic.
Choose RValue such that:
RValue(n+1) = PreImage(RValue(n))
Where n is the commitment index.
Imagine Alice cheats Bob at commitment 100, by sending revocated
Bob only have to remember RValue(99) from the 99th revocation, and
then hash this value 49 times to find out RValue(50)
However, Bob does not know RValue(100) because
RValue(100) = PreImage(99)
For Alice, she only have to generate a random number, then generate let's
say, 1000 hashes. Then she use hashes 1000 for RValue(0), hashes 999 for
Commitment Revocation is only accepted by the party if RValue(n+1) =
The only downside is that Alice need to regenerate all hashes everytimes
a new commitment. This can be mitigated by her storing some pre computed
along the path.
-------------- next part --------------
An HTML attachment was scrubbed...
More information about the Lightning-dev