src/HOL/Auth/NS_Public.thy
author paulson
Tue, 22 Jul 1997 11:21:17 +0200
changeset 3541 2f5ac0f047a6
parent 3519 ab0a9fbed4c0
child 3659 eddedfe2f3f8
permissions -rw-r--r--
Deleted the superfluous assumption A ~= B, which must hold anyway by induction
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
     1
(*  Title:      HOL/Auth/NS_Public
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
     2
    ID:         $Id$
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
     3
    Author:     Lawrence C Paulson, Cambridge University Computer Laboratory
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
     4
    Copyright   1996  University of Cambridge
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
     5
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
     6
Inductive relation "ns_public" for the Needham-Schroeder Public-Key protocol.
2538
c55f68761a8d Mended spelling error
paulson
parents: 2516
diff changeset
     7
Version incorporating Lowe's fix (inclusion of B's identity in round 2).
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
     8
*)
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
     9
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    10
NS_Public = Public + 
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    11
3519
ab0a9fbed4c0 Changing "lost" from a parameter of protocol definitions to a constant.
paulson
parents: 3466
diff changeset
    12
consts  ns_public  :: event list set
2549
0c723635b9e6 Cosmetic improvements
paulson
parents: 2538
diff changeset
    13
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    14
inductive ns_public
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    15
  intrs 
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    16
         (*Initial trace is empty*)
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    17
    Nil  "[]: ns_public"
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    18
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    19
         (*The spy MAY say anything he CAN say.  We do not expect him to
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    20
           invent new nonces here, but he can also use NS1.  Common to
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    21
           all similar protocols.*)
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    22
    Fake "[| evs: ns_public;  B ~= Spy;  
3519
ab0a9fbed4c0 Changing "lost" from a parameter of protocol definitions to a constant.
paulson
parents: 3466
diff changeset
    23
             X: synth (analz (sees Spy evs)) |]
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    24
          ==> Says Spy B X  # evs : ns_public"
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    25
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    26
         (*Alice initiates a protocol run, sending a nonce to Bob*)
2497
47de509bdd55 New treatment of nonce creation
paulson
parents: 2451
diff changeset
    27
    NS1  "[| evs: ns_public;  A ~= B;  Nonce NA ~: used evs |]
47de509bdd55 New treatment of nonce creation
paulson
parents: 2451
diff changeset
    28
          ==> Says A B (Crypt (pubK B) {|Nonce NA, Agent A|})
2451
ce85a2aafc7a Extensive tidying and simplification, largely stemming from
paulson
parents: 2318
diff changeset
    29
                 # evs  :  ns_public"
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    30
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    31
         (*Bob responds to Alice's message with a further nonce*)
2497
47de509bdd55 New treatment of nonce creation
paulson
parents: 2451
diff changeset
    32
    NS2  "[| evs: ns_public;  A ~= B;  Nonce NB ~: used evs;
3466
30791e5a69c4 Corrected indentations and margins after the renaming of "set_of_list"
paulson
parents: 3465
diff changeset
    33
             Says A' B (Crypt (pubK B) {|Nonce NA, Agent A|}) : set evs |]
2497
47de509bdd55 New treatment of nonce creation
paulson
parents: 2451
diff changeset
    34
          ==> Says B A (Crypt (pubK A) {|Nonce NA, Nonce NB, Agent B|})
2451
ce85a2aafc7a Extensive tidying and simplification, largely stemming from
paulson
parents: 2318
diff changeset
    35
                # evs  :  ns_public"
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    36
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    37
         (*Alice proves her existence by sending NB back to Bob.*)
3541
2f5ac0f047a6 Deleted the superfluous assumption A ~= B, which must hold anyway by induction
paulson
parents: 3519
diff changeset
    38
    NS3  "[| evs: ns_public;
3465
e85c24717cad set_of_list -> set
nipkow
parents: 2549
diff changeset
    39
             Says A  B (Crypt (pubK B) {|Nonce NA, Agent A|}) : set evs;
2516
4d68fbe6378b Now with Andy Gordon's treatment of freshness to replace newN/K
paulson
parents: 2497
diff changeset
    40
             Says B' A (Crypt (pubK A) {|Nonce NA, Nonce NB, Agent B|})
3465
e85c24717cad set_of_list -> set
nipkow
parents: 2549
diff changeset
    41
               : set evs |]
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    42
          ==> Says A B (Crypt (pubK B) (Nonce NB)) # evs : ns_public"
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    43
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    44
  (**Oops message??**)
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    45
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    46
end