[tahoe-dev] a crypto puzzle about digital signatures and future compatibility
James A. Donald
jamesd at echeque.com
Thu Aug 27 18:14:32 PDT 2009
Zooko Wilcox-O'Hearn wrote:
> On Wednesday,2009-08-26, at 19:49 , Brian Warner wrote:
>
>> Attack B is where Alice uploads a file, Bob gets the filecap and
>> downloads it, Carol gets the same filecap and downloads it, and
>> Carol desires to see the same file that Bob saw. ... The attackers
>> (who may be Alice and/or other parties) get to craft the filecap
>> and the shares however they like. The attackers win if Bob and
>> Carol accept different documents.
>
> Right, and if we add algorithm agility then this attack is possible
> even if both SHA-2 and SHA-3 are perfectly secure!
>
> Consider this variation of the scenario: Alice generates a filecap
> and gives it to Bob. Bob uses it to fetch a file, reads the file and
> sends the filecap to Carol along with a note saying that he approves
> this file. Carol uses the filecap to fetch the file. The Bob-and-
> Carol team loses if she gets a different file than the one he got.
If Bob and Carol want to be sure they are seeing the same file, have to
use a capability to an immutable file.
Obviously a capability to an immutable file has to commit the file to a
particular hash algorithm.
(Using "capability" in the sense of capabilities as cryptographic data,
capabilities as sparse addresses in a large address space identifying
communication channels)
So the leading bits of the capability have to be an algorithm
identifier. If Bob's tool does not recognize the algorithm, it fails,
and he has to upgrade to a tool that recognizes more algorithms.
If the protocol allows multiple hash types, then the hash has to start
with a number that identifies the algorithm. Yet we want that number to
comprise of very, very few bits.
This is almost precisely the example problem I discuss in
<http://jim.com/security/prefix_free_number_encoding.html>
Now suppose an older algorithm is broken, and Alice wants to show Bob
one file, and Carol another, and pretend they are the same file.
So she just uses the older algorithm. Bob and Carol, however, have the
newer tool, which if the older algorithm is thoroughly broken, will
probably pop up "deprecated algorithm", which Bob and Carol will
cheerfully click through.
If however, the older algorithm has been broken a good long time, and we
are well past the transition period, and no one should be using the
older algorithm any more, except to wrap old format immutable files
inside new format immutable files, then Bob's tool will fail. Problem
solved.
Yes, during the transition period, people can be hosed, especially if
they see nag messages so often that they click them off, as they
probably will, but that is true no matter what. If an algorithm gets
broken, people can be hurt during the transition. The point, however,
is to have a smooth transition, even if security sucks during the
transition.
More information about the tahoe-dev
mailing list