2012-05-02 22:01:08 +01:00
|
|
|
secret fresh k : Function;
|
2006-11-21 13:40:50 +00:00
|
|
|
|
|
|
|
/* Version from the Spore Librairy
|
|
|
|
http://www.lsv.ens-cachan.fr/spore/otwayRees.html
|
|
|
|
*/
|
|
|
|
|
|
|
|
usertype String, SesKey, Ticket, Server;
|
|
|
|
|
|
|
|
protocol otwayrees(A,B,S)
|
|
|
|
{
|
|
|
|
role A
|
|
|
|
{
|
2012-05-02 22:01:08 +01:00
|
|
|
fresh na : Nonce;
|
|
|
|
fresh M : String;
|
2006-11-21 13:40:50 +00:00
|
|
|
var kab : SesKey;
|
|
|
|
|
|
|
|
send_1(A,B, M,A,B, { na,M,A,B }k(A,S) );
|
2012-05-02 22:26:41 +01:00
|
|
|
recv_4(B,A, M, { na,kab }k(A,S) );
|
2006-11-21 13:40:50 +00:00
|
|
|
|
|
|
|
claim_5(A, Secret,kab);
|
|
|
|
claim_5b(A, Niagree);
|
|
|
|
claim_5c(A, Nisynch);
|
|
|
|
}
|
|
|
|
|
|
|
|
role B
|
|
|
|
{
|
|
|
|
var M : String;
|
2012-05-02 22:01:08 +01:00
|
|
|
fresh nb : Nonce;
|
2006-11-21 13:40:50 +00:00
|
|
|
var kab : SesKey;
|
|
|
|
var t1,t2;
|
|
|
|
|
2012-05-02 22:26:41 +01:00
|
|
|
recv_1(A,B, M,A,B, t1 );
|
2006-11-21 13:40:50 +00:00
|
|
|
send_2(B,S, M,A,B, t1, { nb,M,A,B }k(B,S) );
|
2012-05-02 22:26:41 +01:00
|
|
|
recv_3(S,B, M, t2, { nb,kab }k(B,S) );
|
2006-11-21 13:40:50 +00:00
|
|
|
send_4(B,A, M, t2 );
|
|
|
|
|
|
|
|
claim_6(B, Secret,kab);
|
|
|
|
claim_6a(B, Niagree);
|
|
|
|
claim_6b(B, Nisynch);
|
|
|
|
}
|
|
|
|
|
|
|
|
role S
|
|
|
|
{
|
|
|
|
var na,nb : Nonce;
|
|
|
|
var M : String;
|
2012-05-02 22:01:08 +01:00
|
|
|
fresh kab : SesKey;
|
2006-11-21 13:40:50 +00:00
|
|
|
|
2012-05-02 22:26:41 +01:00
|
|
|
recv_2(B,S, M,A,B, { na,M,A,B }k(A,S), { nb,M,A,B }k(B,S) );
|
2006-11-21 13:40:50 +00:00
|
|
|
send_3(S,B, M, { na,kab }k(A,S) , { nb,kab }k(B,S) );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const Alice, Bob, Eve: Agent;
|
|
|
|
const Simon: Server;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|