src/HOL/Auth/Public.thy
author blanchet
Sun, 13 Jan 2013 12:15:43 +0100
changeset 50857 80768e28c9ee
parent 41774 13b97824aec6
child 51717 9e7d1c139569
permissions -rw-r--r--
better handlig of built-ins -- at the top-level, not in subterms
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
37936
1e4c5015a72e updated some headers;
wenzelm
parents: 32630
diff changeset
     1
(*  Title:      HOL/Auth/Public.thy
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
     2
    Author:     Lawrence C Paulson, Cambridge University Computer Laboratory
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
     3
    Copyright   1996  University of Cambridge
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
     4
3512
9dcb4daa15e8 Moving common declarations and proofs from theories "Shared"
paulson
parents: 3478
diff changeset
     5
Theory of Public Keys (common to all public-key protocols)
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
     6
3512
9dcb4daa15e8 Moving common declarations and proofs from theories "Shared"
paulson
parents: 3478
diff changeset
     7
Private and public keys; initial states of agents
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
     8
*)
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
     9
32630
133e4a6474e3 tuned header
haftmann
parents: 32149
diff changeset
    10
theory Public
133e4a6474e3 tuned header
haftmann
parents: 32149
diff changeset
    11
imports Event
133e4a6474e3 tuned header
haftmann
parents: 32149
diff changeset
    12
begin
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    13
14207
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
    14
lemma invKey_K: "K \<in> symKeys ==> invKey K = K"
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
    15
by (simp add: symKeys_def)
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
    16
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    17
subsection{*Asymmetric Keys*}
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    18
18749
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
    19
datatype keymode = Signature | Encryption
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
    20
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    21
consts
18749
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
    22
  publicKey :: "[keymode,agent] => key"
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    23
20768
1d478c2d621f replaced syntax/translations by abbreviation;
wenzelm
parents: 20048
diff changeset
    24
abbreviation
21404
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 20768
diff changeset
    25
  pubEK :: "agent => key" where
20768
1d478c2d621f replaced syntax/translations by abbreviation;
wenzelm
parents: 20048
diff changeset
    26
  "pubEK == publicKey Encryption"
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    27
21404
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 20768
diff changeset
    28
abbreviation
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 20768
diff changeset
    29
  pubSK :: "agent => key" where
20768
1d478c2d621f replaced syntax/translations by abbreviation;
wenzelm
parents: 20048
diff changeset
    30
  "pubSK == publicKey Signature"
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    31
21404
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 20768
diff changeset
    32
abbreviation
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 20768
diff changeset
    33
  privateKey :: "[keymode, agent] => key" where
20768
1d478c2d621f replaced syntax/translations by abbreviation;
wenzelm
parents: 20048
diff changeset
    34
  "privateKey b A == invKey (publicKey b A)"
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    35
21404
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 20768
diff changeset
    36
abbreviation
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    37
  (*BEWARE!! priEK, priSK DON'T WORK with inj, range, image, etc.*)
21404
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 20768
diff changeset
    38
  priEK :: "agent => key" where
20768
1d478c2d621f replaced syntax/translations by abbreviation;
wenzelm
parents: 20048
diff changeset
    39
  "priEK A == privateKey Encryption A"
21404
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 20768
diff changeset
    40
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 20768
diff changeset
    41
abbreviation
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 20768
diff changeset
    42
  priSK :: "agent => key" where
20768
1d478c2d621f replaced syntax/translations by abbreviation;
wenzelm
parents: 20048
diff changeset
    43
  "priSK A == privateKey Signature A"
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    44
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    45
20768
1d478c2d621f replaced syntax/translations by abbreviation;
wenzelm
parents: 20048
diff changeset
    46
text{*These abbreviations give backward compatibility.  They represent the
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    47
simple situation where the signature and encryption keys are the same.*}
20768
1d478c2d621f replaced syntax/translations by abbreviation;
wenzelm
parents: 20048
diff changeset
    48
1d478c2d621f replaced syntax/translations by abbreviation;
wenzelm
parents: 20048
diff changeset
    49
abbreviation
21404
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 20768
diff changeset
    50
  pubK :: "agent => key" where
20768
1d478c2d621f replaced syntax/translations by abbreviation;
wenzelm
parents: 20048
diff changeset
    51
  "pubK A == pubEK A"
1d478c2d621f replaced syntax/translations by abbreviation;
wenzelm
parents: 20048
diff changeset
    52
21404
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 20768
diff changeset
    53
abbreviation
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 20768
diff changeset
    54
  priK :: "agent => key" where
20768
1d478c2d621f replaced syntax/translations by abbreviation;
wenzelm
parents: 20048
diff changeset
    55
  "priK A == invKey (pubEK A)"
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    56
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    57
14126
28824746d046 Tidying and replacement of some axioms by specifications
paulson
parents: 13956
diff changeset
    58
text{*By freeness of agents, no two agents have the same key.  Since
28824746d046 Tidying and replacement of some axioms by specifications
paulson
parents: 13956
diff changeset
    59
  @{term "True\<noteq>False"}, no agent has identical signing and encryption keys*}
28824746d046 Tidying and replacement of some axioms by specifications
paulson
parents: 13956
diff changeset
    60
specification (publicKey)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    61
  injective_publicKey:
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    62
    "publicKey b A = publicKey c A' ==> b=c & A=A'"
18749
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
    63
   apply (rule exI [of _ 
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
    64
       "%b A. 2 * agent_case 0 (\<lambda>n. n + 2) 1 A + keymode_case 0 1 b"])
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
    65
   apply (auto simp add: inj_on_def split: agent.split keymode.split)
23315
df3a7e9ebadb tuned Proof
chaieb
parents: 21619
diff changeset
    66
   apply presburger
df3a7e9ebadb tuned Proof
chaieb
parents: 21619
diff changeset
    67
   apply presburger
14126
28824746d046 Tidying and replacement of some axioms by specifications
paulson
parents: 13956
diff changeset
    68
   done                       
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    69
14126
28824746d046 Tidying and replacement of some axioms by specifications
paulson
parents: 13956
diff changeset
    70
41774
13b97824aec6 modernized specifications;
wenzelm
parents: 39278
diff changeset
    71
axiomatization where
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    72
  (*No private key equals any public key (essential to ensure that private
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    73
    keys are private!) *)
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    74
  privateKey_neq_publicKey [iff]: "privateKey b A \<noteq> publicKey c A'"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    75
18749
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
    76
lemmas publicKey_neq_privateKey = privateKey_neq_publicKey [THEN not_sym]
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
    77
declare publicKey_neq_privateKey [iff]
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    78
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    79
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
    80
subsection{*Basic properties of @{term pubK} and @{term priK}*}
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    81
18570
ffce25f9aa7f a few more named lemmas
paulson
parents: 17990
diff changeset
    82
lemma publicKey_inject [iff]: "(publicKey b A = publicKey c A') = (b=c & A=A')"
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    83
by (blast dest!: injective_publicKey) 
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    84
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    85
lemma not_symKeys_pubK [iff]: "publicKey b A \<notin> symKeys"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
    86
by (simp add: symKeys_def)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    87
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    88
lemma not_symKeys_priK [iff]: "privateKey b A \<notin> symKeys"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
    89
by (simp add: symKeys_def)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    90
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    91
lemma symKey_neq_priEK: "K \<in> symKeys ==> K \<noteq> priEK A"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    92
by auto
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    93
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    94
lemma symKeys_neq_imp_neq: "(K \<in> symKeys) \<noteq> (K' \<in> symKeys) ==> K \<noteq> K'"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
    95
by blast
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    96
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
    97
lemma symKeys_invKey_iff [iff]: "(invKey K \<in> symKeys) = (K \<in> symKeys)"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
    98
by (unfold symKeys_def, auto)
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
    99
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   100
lemma analz_symKeys_Decrypt:
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   101
     "[| Crypt K X \<in> analz H;  K \<in> symKeys;  Key K \<in> analz H |]  
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   102
      ==> X \<in> analz H"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   103
by (auto simp add: symKeys_def)
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   104
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   105
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   106
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   107
subsection{*"Image" equations that hold for injective functions*}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   108
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   109
lemma invKey_image_eq [simp]: "(invKey x \<in> invKey`A) = (x \<in> A)"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   110
by auto
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   111
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   112
(*holds because invKey is injective*)
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   113
lemma publicKey_image_eq [simp]:
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   114
     "(publicKey b x \<in> publicKey c ` AA) = (b=c & x \<in> AA)"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   115
by auto
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   116
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   117
lemma privateKey_notin_image_publicKey [simp]: "privateKey b x \<notin> publicKey c ` AA"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   118
by auto
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   119
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   120
lemma privateKey_image_eq [simp]:
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   121
     "(privateKey b A \<in> invKey ` publicKey c ` AS) = (b=c & A\<in>AS)"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   122
by auto
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   123
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   124
lemma publicKey_notin_image_privateKey [simp]: "publicKey b A \<notin> invKey ` publicKey c ` AS"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   125
by auto
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   126
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   127
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   128
subsection{*Symmetric Keys*}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   129
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   130
text{*For some protocols, it is convenient to equip agents with symmetric as
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   131
well as asymmetric keys.  The theory @{text Shared} assumes that all keys
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   132
are symmetric.*}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   133
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   134
consts
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   135
  shrK    :: "agent => key"    --{*long-term shared keys*}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   136
14126
28824746d046 Tidying and replacement of some axioms by specifications
paulson
parents: 13956
diff changeset
   137
specification (shrK)
28824746d046 Tidying and replacement of some axioms by specifications
paulson
parents: 13956
diff changeset
   138
  inj_shrK: "inj shrK"
28824746d046 Tidying and replacement of some axioms by specifications
paulson
parents: 13956
diff changeset
   139
  --{*No two agents have the same long-term key*}
28824746d046 Tidying and replacement of some axioms by specifications
paulson
parents: 13956
diff changeset
   140
   apply (rule exI [of _ "agent_case 0 (\<lambda>n. n + 2) 1"]) 
28824746d046 Tidying and replacement of some axioms by specifications
paulson
parents: 13956
diff changeset
   141
   apply (simp add: inj_on_def split: agent.split) 
28824746d046 Tidying and replacement of some axioms by specifications
paulson
parents: 13956
diff changeset
   142
   done
28824746d046 Tidying and replacement of some axioms by specifications
paulson
parents: 13956
diff changeset
   143
41774
13b97824aec6 modernized specifications;
wenzelm
parents: 39278
diff changeset
   144
axiomatization where
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   145
  sym_shrK [iff]: "shrK X \<in> symKeys" --{*All shared keys are symmetric*}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   146
18570
ffce25f9aa7f a few more named lemmas
paulson
parents: 17990
diff changeset
   147
text{*Injectiveness: Agents' long-term keys are distinct.*}
ffce25f9aa7f a few more named lemmas
paulson
parents: 17990
diff changeset
   148
lemmas shrK_injective = inj_shrK [THEN inj_eq]
ffce25f9aa7f a few more named lemmas
paulson
parents: 17990
diff changeset
   149
declare shrK_injective [iff]
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   150
14207
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   151
lemma invKey_shrK [simp]: "invKey (shrK A) = shrK A"
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   152
by (simp add: invKey_K) 
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   153
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   154
lemma analz_shrK_Decrypt:
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   155
     "[| Crypt (shrK A) X \<in> analz H; Key(shrK A) \<in> analz H |] ==> X \<in> analz H"
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   156
by auto
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   157
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   158
lemma analz_Decrypt':
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   159
     "[| Crypt K X \<in> analz H; K \<in> symKeys; Key K \<in> analz H |] ==> X \<in> analz H"
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   160
by (auto simp add: invKey_K)
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   161
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   162
lemma priK_neq_shrK [iff]: "shrK A \<noteq> privateKey b C"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   163
by (simp add: symKeys_neq_imp_neq)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   164
18749
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
   165
lemmas shrK_neq_priK = priK_neq_shrK [THEN not_sym]
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
   166
declare shrK_neq_priK [simp]
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   167
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   168
lemma pubK_neq_shrK [iff]: "shrK A \<noteq> publicKey b C"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   169
by (simp add: symKeys_neq_imp_neq)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   170
18749
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
   171
lemmas shrK_neq_pubK = pubK_neq_shrK [THEN not_sym]
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
   172
declare shrK_neq_pubK [simp]
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   173
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   174
lemma priEK_noteq_shrK [simp]: "priEK A \<noteq> shrK B" 
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   175
by auto
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   176
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   177
lemma publicKey_notin_image_shrK [simp]: "publicKey b x \<notin> shrK ` AA"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   178
by auto
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   179
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   180
lemma privateKey_notin_image_shrK [simp]: "privateKey b x \<notin> shrK ` AA"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   181
by auto
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   182
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   183
lemma shrK_notin_image_publicKey [simp]: "shrK x \<notin> publicKey b ` AA"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   184
by auto
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   185
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   186
lemma shrK_notin_image_privateKey [simp]: "shrK x \<notin> invKey ` publicKey b ` AA" 
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   187
by auto
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   188
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   189
lemma shrK_image_eq [simp]: "(shrK x \<in> shrK ` AA) = (x \<in> AA)"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   190
by auto
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   191
14207
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   192
text{*For some reason, moving this up can make some proofs loop!*}
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   193
declare invKey_K [simp]
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   194
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   195
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   196
subsection{*Initial States of Agents*}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   197
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   198
text{*Note: for all practical purposes, all that matters is the initial
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   199
knowledge of the Spy.  All other agents are automata, merely following the
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   200
protocol.*}
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
   201
39246
9e58f0499f57 modernized primrec
haftmann
parents: 37936
diff changeset
   202
overloading
9e58f0499f57 modernized primrec
haftmann
parents: 37936
diff changeset
   203
  initState \<equiv> initState
9e58f0499f57 modernized primrec
haftmann
parents: 37936
diff changeset
   204
begin
9e58f0499f57 modernized primrec
haftmann
parents: 37936
diff changeset
   205
9e58f0499f57 modernized primrec
haftmann
parents: 37936
diff changeset
   206
primrec initState where
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
   207
        (*Agents know their private key and all public keys*)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   208
  initState_Server:
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   209
    "initState Server     =    
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   210
       {Key (priEK Server), Key (priSK Server)} \<union> 
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   211
       (Key ` range pubEK) \<union> (Key ` range pubSK) \<union> (Key ` range shrK)"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   212
39246
9e58f0499f57 modernized primrec
haftmann
parents: 37936
diff changeset
   213
| initState_Friend:
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   214
    "initState (Friend i) =    
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   215
       {Key (priEK(Friend i)), Key (priSK(Friend i)), Key (shrK(Friend i))} \<union> 
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   216
       (Key ` range pubEK) \<union> (Key ` range pubSK)"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   217
39246
9e58f0499f57 modernized primrec
haftmann
parents: 37936
diff changeset
   218
| initState_Spy:
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   219
    "initState Spy        =    
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   220
       (Key ` invKey ` pubEK ` bad) \<union> (Key ` invKey ` pubSK ` bad) \<union> 
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   221
       (Key ` shrK ` bad) \<union> 
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   222
       (Key ` range pubEK) \<union> (Key ` range pubSK)"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   223
39246
9e58f0499f57 modernized primrec
haftmann
parents: 37936
diff changeset
   224
end
9e58f0499f57 modernized primrec
haftmann
parents: 37936
diff changeset
   225
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   226
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   227
text{*These lemmas allow reasoning about @{term "used evs"} rather than
13935
paulson
parents: 13926
diff changeset
   228
   @{term "knows Spy evs"}, which is useful when there are private Notes. 
paulson
parents: 13926
diff changeset
   229
   Because they depend upon the definition of @{term initState}, they cannot
paulson
parents: 13926
diff changeset
   230
   be moved up.*}
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   231
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   232
lemma used_parts_subset_parts [rule_format]:
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   233
     "\<forall>X \<in> used evs. parts {X} \<subseteq> used evs"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   234
apply (induct evs) 
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   235
 prefer 2
39251
8756b44582e2 Tidied up proofs using sledgehammer, also deleting unnecessary semicolons
paulson
parents: 39246
diff changeset
   236
 apply (simp add: used_Cons split: event.split)
8756b44582e2 Tidied up proofs using sledgehammer, also deleting unnecessary semicolons
paulson
parents: 39246
diff changeset
   237
 apply (metis Un_iff empty_subsetI insert_subset le_supI1 le_supI2 parts_subset_iff)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   238
txt{*Base case*}
39251
8756b44582e2 Tidied up proofs using sledgehammer, also deleting unnecessary semicolons
paulson
parents: 39246
diff changeset
   239
apply (auto dest!: parts_cut simp add: used_Nil) 
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   240
done
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   241
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   242
lemma MPair_used_D: "{|X,Y|} \<in> used H ==> X \<in> used H & Y \<in> used H"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   243
by (drule used_parts_subset_parts, simp, blast)
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   244
17990
86d462f305e0 tidied away duplicate thm
paulson
parents: 16417
diff changeset
   245
text{*There was a similar theorem in Event.thy, so perhaps this one can
86d462f305e0 tidied away duplicate thm
paulson
parents: 16417
diff changeset
   246
  be moved up if proved directly by induction.*}
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   247
lemma MPair_used [elim!]:
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   248
     "[| {|X,Y|} \<in> used H;
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   249
         [| X \<in> used H; Y \<in> used H |] ==> P |] 
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   250
      ==> P"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   251
by (blast dest: MPair_used_D) 
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   252
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   253
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   254
text{*Rewrites should not refer to  @{term "initState(Friend i)"} because
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   255
  that expression is not in normal form.*}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   256
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   257
lemma keysFor_parts_initState [simp]: "keysFor (parts (initState C)) = {}"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   258
apply (unfold keysFor_def)
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   259
apply (induct_tac "C")
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   260
apply (auto intro: range_eqI)
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   261
done
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   262
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   263
lemma Crypt_notin_initState: "Crypt K X \<notin> parts (initState B)"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   264
by (induct B, auto)
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   265
13935
paulson
parents: 13926
diff changeset
   266
lemma Crypt_notin_used_empty [simp]: "Crypt K X \<notin> used []"
paulson
parents: 13926
diff changeset
   267
by (simp add: Crypt_notin_initState used_Nil)
paulson
parents: 13926
diff changeset
   268
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   269
(*** Basic properties of shrK ***)
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   270
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   271
(*Agents see their own shared keys!*)
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   272
lemma shrK_in_initState [iff]: "Key (shrK A) \<in> initState A"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   273
by (induct_tac "A", auto)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   274
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   275
lemma shrK_in_knows [iff]: "Key (shrK A) \<in> knows A evs"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   276
by (simp add: initState_subset_knows [THEN subsetD])
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   277
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   278
lemma shrK_in_used [iff]: "Key (shrK A) \<in> used evs"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   279
by (rule initState_into_used, blast)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   280
14207
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   281
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   282
(** Fresh keys never clash with long-term shared keys **)
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   283
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   284
(*Used in parts_induct_tac and analz_Fake_tac to distinguish session keys
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   285
  from long-term shared keys*)
14207
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   286
lemma Key_not_used [simp]: "Key K \<notin> used evs ==> K \<notin> range shrK"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   287
by blast
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   288
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   289
lemma shrK_neq: "Key K \<notin> used evs ==> shrK B \<noteq> K"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   290
by blast
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   291
18749
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
   292
lemmas neq_shrK = shrK_neq [THEN not_sym]
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
   293
declare neq_shrK [simp]
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
   294
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
   295
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   296
subsection{*Function @{term spies} *}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   297
18749
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
   298
lemma not_SignatureE [elim!]: "b \<noteq> Signature \<Longrightarrow> b = Encryption"
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
   299
  by (cases b, auto) 
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
   300
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   301
text{*Agents see their own private keys!*}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   302
lemma priK_in_initState [iff]: "Key (privateKey b A) \<in> initState A"
18749
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
   303
  by (cases A, auto)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   304
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   305
text{*Agents see all public keys!*}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   306
lemma publicKey_in_initState [iff]: "Key (publicKey b A) \<in> initState B"
18749
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
   307
  by (cases B, auto) 
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   308
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   309
text{*All public keys are visible*}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   310
lemma spies_pubK [iff]: "Key (publicKey b A) \<in> spies evs"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   311
apply (induct_tac "evs")
18749
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
   312
apply (auto simp add: imageI knows_Cons split add: event.split)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   313
done
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   314
18749
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
   315
lemmas analz_spies_pubK = spies_pubK [THEN analz.Inj]
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
   316
declare analz_spies_pubK [iff]
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   317
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   318
text{*Spy sees private keys of bad agents!*}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   319
lemma Spy_spies_bad_privateKey [intro!]:
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   320
     "A \<in> bad ==> Key (privateKey b A) \<in> spies evs"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   321
apply (induct_tac "evs")
18749
31c2af8b0c60 replacement of bool by a datatype (making problems first-order). More lemma names
paulson
parents: 18570
diff changeset
   322
apply (auto simp add: imageI knows_Cons split add: event.split)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   323
done
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   324
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   325
text{*Spy sees long-term shared keys of bad agents!*}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   326
lemma Spy_spies_bad_shrK [intro!]:
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   327
     "A \<in> bad ==> Key (shrK A) \<in> spies evs"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   328
apply (induct_tac "evs")
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   329
apply (simp_all add: imageI knows_Cons split add: event.split)
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   330
done
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   331
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   332
lemma publicKey_into_used [iff] :"Key (publicKey b A) \<in> used evs"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   333
apply (rule initState_into_used)
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   334
apply (rule publicKey_in_initState [THEN parts.Inj])
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   335
done
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   336
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   337
lemma privateKey_into_used [iff]: "Key (privateKey b A) \<in> used evs"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   338
apply(rule initState_into_used)
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   339
apply(rule priK_in_initState [THEN parts.Inj])
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   340
done
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   341
14207
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   342
(*For case analysis on whether or not an agent is compromised*)
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   343
lemma Crypt_Spy_analz_bad:
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   344
     "[| Crypt (shrK A) X \<in> analz (knows Spy evs);  A \<in> bad |]  
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   345
      ==> X \<in> analz (knows Spy evs)"
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   346
by force
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   347
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   348
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   349
subsection{*Fresh Nonces*}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   350
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   351
lemma Nonce_notin_initState [iff]: "Nonce N \<notin> parts (initState B)"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   352
by (induct_tac "B", auto)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   353
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   354
lemma Nonce_notin_used_empty [simp]: "Nonce N \<notin> used []"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   355
by (simp add: used_Nil)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   356
11104
f2024fed9f0c partial conversion to Isar script style
paulson
parents: 10833
diff changeset
   357
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   358
subsection{*Supply fresh nonces for possibility theorems*}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   359
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   360
text{*In any trace, there is an upper bound N on the greatest nonce in use*}
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   361
lemma Nonce_supply_lemma: "EX N. ALL n. N<=n --> Nonce n \<notin> used evs"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   362
apply (induct_tac "evs")
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   363
apply (rule_tac x = 0 in exI)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   364
apply (simp_all (no_asm_simp) add: used_Cons split add: event.split)
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   365
apply safe
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   366
apply (rule msg_Nonce_supply [THEN exE], blast elim!: add_leE)+
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   367
done
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   368
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   369
lemma Nonce_supply1: "EX N. Nonce N \<notin> used evs"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   370
by (rule Nonce_supply_lemma [THEN exE], blast)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   371
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   372
lemma Nonce_supply: "Nonce (@ N. Nonce N \<notin> used evs) \<notin> used evs"
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   373
apply (rule Nonce_supply_lemma [THEN exE])
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   374
apply (rule someI, fast)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   375
done
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   376
13956
8fe7e12290e1 improved presentation of HOL/Auth theories
paulson
parents: 13935
diff changeset
   377
subsection{*Specialized Rewriting for Theorems About @{term analz} and Image*}
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   378
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   379
lemma insert_Key_singleton: "insert (Key K) H = Key ` {K} Un H"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   380
by blast
11104
f2024fed9f0c partial conversion to Isar script style
paulson
parents: 10833
diff changeset
   381
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   382
lemma insert_Key_image: "insert (Key K) (Key`KK \<union> C) = Key ` (insert K KK) \<union> C"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   383
by blast
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   384
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   385
14207
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   386
lemma Crypt_imp_keysFor :"[|Crypt K X \<in> H; K \<in> symKeys|] ==> K \<in> keysFor H"
13926
6e62e5357a10 converting more HOL-Auth to new-style theories
paulson
parents: 13922
diff changeset
   387
by (drule Crypt_imp_invKey_keysFor, simp)
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   388
14207
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   389
text{*Lemma for the trivial direction of the if-and-only-if of the 
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   390
Session Key Compromise Theorem*}
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   391
lemma analz_image_freshK_lemma:
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   392
     "(Key K \<in> analz (Key`nE \<union> H)) --> (K \<in> nE | Key K \<in> analz H)  ==>  
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   393
         (Key K \<in> analz (Key`nE \<union> H)) = (K \<in> nE | Key K \<in> analz H)"
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   394
by (blast intro: analz_mono [THEN [2] rev_subsetD])
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   395
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   396
lemmas analz_image_freshK_simps =
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   397
       simp_thms mem_simps --{*these two allow its use with @{text "only:"}*}
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   398
       disj_comms 
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   399
       image_insert [THEN sym] image_Un [THEN sym] empty_subsetI insert_subset
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   400
       analz_insert_eq Un_upper2 [THEN analz_mono, THEN subsetD]
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   401
       insert_Key_singleton 
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   402
       Key_not_used insert_Key_image Un_assoc [THEN sym]
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   403
21619
dea0914773f7 stripped some legacy bindings
haftmann
parents: 21588
diff changeset
   404
ML {*
24122
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   405
structure Public =
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   406
struct
14207
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   407
24122
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   408
val analz_image_freshK_ss = @{simpset} delsimps [image_insert, image_Un]
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   409
  delsimps [@{thm imp_disjL}]    (*reduces blow-up*)
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   410
  addsimps @{thms analz_image_freshK_simps}
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   411
23894
1a4167d761ac tactics: avoid dynamic reference to accidental theory context (via ML_Context.the_context etc.);
wenzelm
parents: 23315
diff changeset
   412
(*Tactic for possibility theorems*)
1a4167d761ac tactics: avoid dynamic reference to accidental theory context (via ML_Context.the_context etc.);
wenzelm
parents: 23315
diff changeset
   413
fun possibility_tac ctxt =
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   414
    REPEAT (*omit used_Says so that Nonces start from different traces!*)
32149
ef59550a55d3 renamed simpset_of to global_simpset_of, and local_simpset_of to simpset_of -- same for claset and clasimpset;
wenzelm
parents: 30549
diff changeset
   415
    (ALLGOALS (simp_tac (simpset_of ctxt delsimps [@{thm used_Says}]))
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   416
     THEN
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   417
     REPEAT_FIRST (eq_assume_tac ORELSE' 
23894
1a4167d761ac tactics: avoid dynamic reference to accidental theory context (via ML_Context.the_context etc.);
wenzelm
parents: 23315
diff changeset
   418
                   resolve_tac [refl, conjI, @{thm Nonce_supply}]))
14207
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   419
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   420
(*For harder protocols (such as Recur) where we have to set up some
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   421
  nonces and keys initially*)
23894
1a4167d761ac tactics: avoid dynamic reference to accidental theory context (via ML_Context.the_context etc.);
wenzelm
parents: 23315
diff changeset
   422
fun basic_possibility_tac ctxt =
14207
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   423
    REPEAT 
32149
ef59550a55d3 renamed simpset_of to global_simpset_of, and local_simpset_of to simpset_of -- same for claset and clasimpset;
wenzelm
parents: 30549
diff changeset
   424
    (ALLGOALS (asm_simp_tac (simpset_of ctxt setSolver safe_solver))
14207
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   425
     THEN
f20fbb141673 Conversion of all main protocols from "Shared" to "Public".
paulson
parents: 14200
diff changeset
   426
     REPEAT_FIRST (resolve_tac [refl, conjI]))
24122
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   427
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   428
end
13922
75ae4244a596 Changes required by the certified email protocol
paulson
parents: 11287
diff changeset
   429
*}
11104
f2024fed9f0c partial conversion to Isar script style
paulson
parents: 10833
diff changeset
   430
24122
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   431
method_setup analz_freshK = {*
30549
d2d7874648bd simplified method setup;
wenzelm
parents: 30510
diff changeset
   432
    Scan.succeed (fn ctxt =>
30510
4120fc59dd85 unified type Proof.method and pervasive METHOD combinators;
wenzelm
parents: 24122
diff changeset
   433
     (SIMPLE_METHOD
24122
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   434
      (EVERY [REPEAT_FIRST (resolve_tac [allI, ballI, impI]),
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   435
          REPEAT_FIRST (rtac @{thm analz_image_freshK_lemma}),
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   436
          ALLGOALS (asm_simp_tac (Simplifier.context ctxt Public.analz_image_freshK_ss))]))) *}
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   437
    "for proving the Session Key Compromise theorem"
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   438
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   439
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   440
subsection{*Specialized Methods for Possibility Theorems*}
fc7f857d33c8 tuned ML bindings (for multithreading);
wenzelm
parents: 23894
diff changeset
   441
11104
f2024fed9f0c partial conversion to Isar script style
paulson
parents: 10833
diff changeset
   442
method_setup possibility = {*
30549
d2d7874648bd simplified method setup;
wenzelm
parents: 30510
diff changeset
   443
    Scan.succeed (SIMPLE_METHOD o Public.possibility_tac) *}
23894
1a4167d761ac tactics: avoid dynamic reference to accidental theory context (via ML_Context.the_context etc.);
wenzelm
parents: 23315
diff changeset
   444
    "for proving possibility theorems"
1a4167d761ac tactics: avoid dynamic reference to accidental theory context (via ML_Context.the_context etc.);
wenzelm
parents: 23315
diff changeset
   445
1a4167d761ac tactics: avoid dynamic reference to accidental theory context (via ML_Context.the_context etc.);
wenzelm
parents: 23315
diff changeset
   446
method_setup basic_possibility = {*
30549
d2d7874648bd simplified method setup;
wenzelm
parents: 30510
diff changeset
   447
    Scan.succeed (SIMPLE_METHOD o Public.basic_possibility_tac) *}
11104
f2024fed9f0c partial conversion to Isar script style
paulson
parents: 10833
diff changeset
   448
    "for proving possibility theorems"
2318
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
   449
6d3f7c7f70b0 Public-key examples
paulson
parents:
diff changeset
   450
end