Zero Knowledge Identity Proofs

2001-06-24 Thread Michael Conlen

I'm reading about zero knowledge identity proofs and 'The Mafia Fraud' in
Applied Cryptography. Has no one found a way to perform an identity proof
such that you can prove who you are to a specific person? In the example in
the book Alice proves who she is to Bob who transmits to Carol, and Carol
proves that she is Alice to Dave. I'm curious what the problem is with
creating a proof that Alice is Alice such that only Bob can be assured that
she is Alice so that Carol can't use the proof to identify who she is to
Dave.

--
Groove On Dude
Michael Conlen
Obfuscated Networking
[EMAIL PROTECTED]





-
The Cryptography Mailing List
Unsubscribe by sending "unsubscribe cryptography" to [EMAIL PROTECTED]



Re: Zero Knowledge Identity Proofs

2001-06-25 Thread Helger Lipmaa

On Sun, 24 Jun 2001, Michael Conlen wrote:

> I'm reading about zero knowledge identity proofs and 'The Mafia Fraud' in
> Applied Cryptography. Has no one found a way to perform an identity proof
> such that you can prove who you are to a specific person? In the example in
> the book Alice proves who she is to Bob who transmits to Carol, and Carol
> proves that she is Alice to Dave. I'm curious what the problem is with
> creating a proof that Alice is Alice such that only Bob can be assured that
> she is Alice so that Carol can't use the proof to identify who she is to
> Dave.

THe proofs that you are requesting for have been standard tools in
cryptography for many years - they are usually known as identification
schemes. The best known scheme (and most elegant IMHO) is the Schnorr
identification scheme. See

http://www.tml.hut.fi/~helger/crypto/link/identification/

for a (noncomplete) collection of links.

Helger





-
The Cryptography Mailing List
Unsubscribe by sending "unsubscribe cryptography" to [EMAIL PROTECTED]



Re: Zero Knowledge Identity Proofs

2001-06-25 Thread Dimitrios . Petropoulos


I think this is a case for additional protective mechanisms to extend the protocol 
semantics (there is nothing in the protocol prohibiting the verifier to perform a 
verification on behalf of a third party, which is the vulnerability exploited in the 
Mafia Fraud attack). This 'challenge-relay' can easily be defeated if the verifier (in 
the Mafia Fraud case that's Bob and Dave) is required to digitally sign their 
challenges. If challenges are signed then Alice will only proceed with the rest of the 
protocol run if the challenge indeed comes from Bob; Carol can still pass Dave's 
challenges to Bob but Alice will refuse to perform the protocol run having noticed 
that the challenges do not come from Bob. The optimised versions of the 
Feige-Fiat-Shamir and Guillou-Quisquater protocols make signing easier since they 
employ a vector of challenges to perform multiple accreditations- in order to avoid 
multiple messages.

Regards,
Dimitrios Petropoulos


> I'm reading about zero knowledge identity proofs and 'The Mafia Fraud' in
> Applied Cryptography. Has no one found a way to perform an identity proof
> such that you can prove who you are to a specific person? In the example in
> the book Alice proves who she is to Bob who transmits to Carol, and Carol
> proves that she is Alice to Dave. I'm curious what the problem is with
> creating a proof that Alice is Alice such that only Bob can be assured that
> she is Alice so that Carol can't use the proof to identify who she is to
> Dave.
>
> --
> Groove On Dude
> Michael Conlen
> Obfuscated Networking
> [EMAIL PROTECTED]
>




-
Visit our Internet site at http://www.reuters.com

Any views expressed in this message are those of  the  individual
sender,  except  where  the sender specifically states them to be
the views of Reuters Ltd.



-
The Cryptography Mailing List
Unsubscribe by sending "unsubscribe cryptography" to [EMAIL PROTECTED]



Re: Zero Knowledge Identity Proofs

2001-06-25 Thread Marc Branchaud


I'm not hep to the identification scheme literature, but I'll just a note
that in Dimitrios's scheme, Alice can't just sign the challenge, but must
also include Dave's signature in her signature.  That is, Alice must sign all
of {S_dave(challenge), challenge}, not just the challenge by itself.  And
Dave has to verify that both the challenge and his signature were signed by
Alice.  Otherwise, Bob could just masquerade Dave's challenge.

Marc


[EMAIL PROTECTED] wrote:
> 
> I think this is a case for additional protective mechanisms to extend the
> protocol semantics (there is nothing in the protocol prohibiting the
> verifier to perform a verification on behalf of a third party, which is
> the vulnerability exploited in the Mafia Fraud attack). This
> 'challenge-relay' can easily be defeated if the verifier (in the Mafia
> Fraud case that's Bob and Dave) is required to digitally sign their
> challenges. If challenges are signed then Alice will only proceed with
> the rest of the protocol run if the challenge indeed comes from Bob;
> Carol can still pass Dave's challenges to Bob but Alice will refuse to
> perform the protocol run having noticed that the challenges do not come
> from Bob. The optimised versions of the Feige-Fiat-Shamir and Guillou-
> Quisquater protocols make signing easier since they employ a vector of
> challenges to perform multiple accreditations- in order to avoid
> multiple messages.
> 
> Regards,
> Dimitrios Petropoulos



-
The Cryptography Mailing List
Unsubscribe by sending "unsubscribe cryptography" to [EMAIL PROTECTED]



Re: Zero Knowledge Identity Proofs

2001-06-26 Thread Dimitrios . Petropoulos


Interestingly enough, I don't think this is the case because the objective is to 
prevent Alice from acting on  Dave's challenges. The confusion may also have arisen 
because of my use of terms. In this email I'll use 'signing' to mean creation of proof 
of origin (and classic digital signature algorithms like RSA will suffice). When an 
entity is trying to prove their identity I'll refer to it as 'acting on' or 
'transforming' a challenge. I'll try to clarify:

Alice does not need to 'sign' any challenge since she is the 'prover', i.e. the entity 
that needs to prove the truthfulness and genuineness of her identity to Bob, who is 
the 'verifier' and therefore the entity producing the challenges. In the course of 
proving her identity to Bob using a zero knowledge proof of identity, Alice will 
accept a number of challenges from Bob (the number of which Bob has to decide 
depending on his perception of risk; each iteration reduces the likelihood of 
successful impersonation by half), perform some transformations and return the result 
to Bob who will verify the transformations.

In this scheme, Alice can fall victim to Bob and Carol working together to defraud 
both Alice and Dave (the Mafia Fraud example), whereby Carol masquerades as Alice to 
Dave and relays Dave's challenges -through Bob- to Alice, who will perform the 
transformations believing she is proving her identity to Bob (when in fact she is 
proving it to Dave).

Digital signatures (e.g. RSA) on the challenge vectors (along with sensible additional 
information like prover & verifier identities, timestamps/nonces, etc. to prevent 
other attacks on the message semantics) would prevent the Mafia Fraud attack since -in 
this example- Alice would only perform the protocol run if the challenge vector is 
signed by Bob, whereas Dave will send challenge vectors carrying his signature to 
Carol (which can no longer relay them to Alice).

I cannot see why Alice would have to transform both the challenge and the signature on 
it (this, incidentally, would mean that you cannot use signatures with message 
recovery). Apologies if there's something in Marc's email that I have misunderstood; 
grateful if I could have it pointed out to me.

Regards,
Dimitrios Petropoulos

> I'm not hep to the identification scheme literature, but I'll just a note
> that in Dimitrios's scheme, Alice can't just sign the challenge, but must
> also include Dave's signature in her signature.  That is, Alice must sign all
> of {S_dave(challenge), challenge}, not just the challenge by itself.  And
> Dave has to verify that both the challenge and his signature were signed by
> Alice.  Otherwise, Bob could just masquerade Dave's challenge.
>
> Marc
>
>
> [EMAIL PROTECTED] wrote:
> >
> > I think this is a case for additional protective mechanisms to extend the
> > protocol semantics (there is nothing in the protocol prohibiting the
> > verifier to perform a verification on behalf of a third party, which is
> > the vulnerability exploited in the Mafia Fraud attack). This
> > 'challenge-relay' can easily be defeated if the verifier (in the Mafia
> > Fraud case that's Bob and Dave) is required to digitally sign their
> > challenges. If challenges are signed then Alice will only proceed with
> > the rest of the protocol run if the challenge indeed comes from Bob;
> > Carol can still pass Dave's challenges to Bob but Alice will refuse to
> > perform the protocol run having noticed that the challenges do not come
> > from Bob. The optimised versions of the Feige-Fiat-Shamir and Guillou-
> > Quisquater protocols make signing easier since they employ a vector of
> > challenges to perform multiple accreditations- in order to avoid
> > multiple messages.
> >
> > Regards,
> > Dimitrios Petropoulos
>
>
>
> -
> The Cryptography Mailing List
> Unsubscribe by sending "unsubscribe cryptography" to
> [EMAIL PROTECTED]



-
Visit our Internet site at http://www.reuters.com

Any views expressed in this message are those of  the  individual
sender,  except  where  the sender specifically states them to be
the views of Reuters Ltd.



-
The Cryptography Mailing List
Unsubscribe by sending "unsubscribe cryptography" to [EMAIL PROTECTED]



Re: Zero Knowledge Identity Proofs

2001-06-26 Thread Dimitrios . Petropoulos


Following up on my previous post (netiquette? what's that?) one further clarification 
(and summary of my thoughts): the heart of the Mafia Fraud attack lies -I think- in 
that the challenge messages provide no proof of origin (who created them) nor of 
intended recipient (who were they intended for). A simple extension of the challenge 
message to include this information, protected with a simple digital signature scheme, 
is -in my opinion- enough to overcome the problem.

Regards,
Dimitrios Petropoulos





-
Visit our Internet site at http://www.reuters.com

Any views expressed in this message are those of  the  individual
sender,  except  where  the sender specifically states them to be
the views of Reuters Ltd.



-
The Cryptography Mailing List
Unsubscribe by sending "unsubscribe cryptography" to [EMAIL PROTECTED]



Re: Zero Knowledge Identity Proofs

2001-06-27 Thread Marc Branchaud


Well, I can't be sure that I'm not misunderstanding something either.  For
the most part, I agree with Dimitrios that challenges with proof of origin
are part of the solution to Mafia Fraud attacks.  My main point is that I
don't think simply signing the challenge is enough.

Let me try to restate things symbolically.  Nominally, in the naive case,
Dave would present Alice with a challenge, X, and Alice would transform &
return the challenge: X'.  This, as we know, is vulnerable to the Mafia
Fraud.

What I believe Dimitrios is proposing is for Dave to present both the
challenge and a signature on the challenge: {X, S_dave(X)}.  Then, Alice
would verify that the signature corresponds to the person she thinks she's
talking to, and if so she can return the transformed challenge X'.

I'm essentially contending that Dave needs to verify that Alice did indeed
see the challenge & signature he presented.  Consider Mafia Fraud against the
above scenario.  Dave presents {X, S_dave(X)} to Carol, who forwards it to
Bob.  Now, Bob can re-sign the challenge himself, and present {X, S_bob(X)}
to Alice.  Alice will happily verify that the challenge comes from Bob, and
return X' to Bob, who then passes it to Carol & then on to Dave.   The fraud
is successful, because Dave can't tell that Alice saw Bob's signature on the
challenge and not his own.

So the X' that Alice computes must be a function f(X, S_dave(X)) on both the
challenge and the signature.  (If, in the naive case, X'=S_alice(X), then to
truly prevent the fraud we need X'=S_alice(X,S_dave(X)).)  Now the fraud
fails because Alice would compute X'=f(X, S_bob(X)), and so Dave (not Alice)
would detect the fraud.

So it's not enough for Dave to simply sign the challenge & for Alice to
verify that signature.  Alice must prove to Dave that she saw his signature
and not somebody else's.

BTW, without giving it any thought, I believe this scheme is safe against
replay attacks (because Dave generates a new challenge every time).  Does
anybody have any thoughts about that?

Marc



-
The Cryptography Mailing List
Unsubscribe by sending "unsubscribe cryptography" to [EMAIL PROTECTED]



Re: Zero Knowledge Identity Proofs

2001-06-28 Thread Dimitrios . Petropoulos


I now strongly believe that Marc and I are actually talking about the same thing, only 
we're doing it using different words: Marc talks about Alice providing evidence that 
she has seen Dave's signature on the challenge whereas I talk about the challenge 
vector being accompanied by information identifying the originator and the intended 
recipient, bound/protected via a classical digital signature... In both cases the 
ultimate goal is the same: Alice is provided with guarantees that the challenge was 
intended for her and was produced by the person she thinks she is proving her identity 
to.

Essentially in any challenge-response based entity authentication protocol the 
following must always hold:

Consider an authentication protocol where two entities, A and B, exchange the 
following messages:

A -> B(M1)
A <- B(M2)
A -> B(M3)
A <- B(M4)
...

In the above diagram A starts the protocol by sending message M1 to B. B replies by 
sending message M2 to A, etc. It is assumed that each party sends message Mi only 
after having successfully received (and verified wherever the protocol makes possible) 
message Mi-1.

After completion of the protocol A would like to be sure that :

1. M2, M4, etc. were indeed sent by B
2. M2, M4, etc. were 'fresh' messages, i.e. not replays of older messages
3. M2, M4, etc. were intended for A and not for any other recipient
4. M2, M4, etc. were sent by B as a response to A's M1, M3, etc.

(the above protect respectively against masquerading, replay, reflection and 
interleaving attacks)

Similarly for B:

1. M1, M3, etc. were indeed sent by A
2. M1, M3, etc. were 'fresh' messages, i.e. not replays of older messages
3. M1, M3, etc. were intended for B and not for any other recipient
4. M3, M5, etc. were sent by A as a response to B's M2, M4, etc.

When developing authentication protocols the above requirements are usually fulfilled 
as follows:
(1) via the use of secrets,
(2) via the use of time-variant parameters
(3) by using originator or intended recipient identifiers
(4) by including in Mi information that could only have originated from Mi-1.

The zero knowledge identity proofs can be considered, in my opinion, as low level 
primitives on top of which strong entity authentication protocols can be built. On 
their own (without the extensions discussed above) they will always be vulnerable to a 
number of attacks.

Regarding whether the uniqueness of the challenge vector can protect against replay 
attacks, I guess this depends on the length of the challenge vector. If 10 bits are 
used this makes the likelihood of successful impersonation by an imposter quite small 
(2^-10, i.e. 0.00098) but also the number of different vectors is quite small (2^10, 
i.e. 1024), therefore after 1024 protocol runs you cannot tell whether the responder 
is sending a fresh reply or whether they are replaying something they intercepted 
earlier... In such cases maybe other freshness methods should be used (e.g. 
timestamps, nonces, etc.).

Regards,
Dimitrios Petropoulos


On 27/06/2001 00:00:26 Marc Branchaud wrote:

> Well, I can't be sure that I'm not misunderstanding something either.  For
> the most part, I agree with Dimitrios that challenges with proof of origin
> are part of the solution to Mafia Fraud attacks.  My main point is that I
> don't think simply signing the challenge is enough.
>
> Let me try to restate things symbolically.  Nominally, in the naive case,
> Dave would present Alice with a challenge, X, and Alice would transform &
> return the challenge: X'.  This, as we know, is vulnerable to the Mafia
> Fraud.
>
> What I believe Dimitrios is proposing is for Dave to present both the
> challenge and a signature on the challenge: {X, S_dave(X)}.  Then, Alice
> would verify that the signature corresponds to the person she thinks she's
> talking to, and if so she can return the transformed challenge X'.
>
> I'm essentially contending that Dave needs to verify that Alice did indeed
> see the challenge & signature he presented.  Consider Mafia Fraud against the
> above scenario.  Dave presents {X, S_dave(X)} to Carol, who forwards it to
> Bob.  Now, Bob can re-sign the challenge himself, and present {X, S_bob(X)}
> to Alice.  Alice will happily verify that the challenge comes from Bob, and
> return X' to Bob, who then passes it to Carol & then on to Dave.   The fraud
> is successful, because Dave can't tell that Alice saw Bob's signature on the
> challenge and not his own.
>
> So the X' that Alice computes must be a function f(X, S_dave(X)) on both the
> challenge and the signature.  (If, in the naive case, X'=S_alice(X), then to
> truly prevent the fraud we need X'=S_alice(X,S_dave(X)).)  Now the fraud
> fails because Alice would compute X'=f(X, S_