-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhpke.auth.outsider-auth.ocv
330 lines (274 loc) · 10.8 KB
/
hpke.auth.outsider-auth.ocv
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
(* Analysing the HPKE Standard - Supplementary Material
Joël Alwen; Bruno Blanchet; Eduard Hauck; Eike Kiltz; Benjamin Lipp;
Doreen Riepel
This is supplementary material accompanying the paper:
Joël Alwen, Bruno Blanchet, Eduard Hauck, Eike Kiltz, Benjamin Lipp,
and Doreen Riepel. Analysing the HPKE Standard. In Anne Canteaut and
Francois-Xavier Standaert, editors, Eurocrypt 2021, Lecture Notes in
Computer Science, pages 87-116, Zagreb, Croatia, October 2021. Springer.
Long version: https://eprint.iacr.org/2020/1499 *)
proof {
out_game "g00.out.cv";
remove_assign binder the_sk;
remove_assign binder the_pk;
out_game "g01.out.cv";
crypto outsider_cca(AuthEncap) [variables: s->s_1];
out_game "g02.out.cv";
SArename k_2;
out_game "g03.out.cv";
crypto outsider_auth(AuthEncap) [variables: s->s_1];
out_game "g04.out.cv";
crypto eliminate_failing(AuthEncap) **;
out_game "g05.out.cv";
crypto prf(KeySchedule_auth) k'_1 k'_2 k'_3;
out_game "g06.out.cv";
crypto splitter(split) **;
out_game "g07.out.cv";
crypto int_ctxt(Seal_inner) part1_7 part1_6 part1_2 part1_3 part1_5 part1_1 part1;
out_game "g08.out.cv";
success
}
(** Key Encapsulation Mechanism **)
type keypairseed_t [bounded,large].
type kemseed_t [fixed,large].
type skey_t [bounded,large].
type pkey_t [bounded,large].
type kemkey_t [fixed,large].
type kemciph_t [fixed,large].
type AuthEncap_res_t [fixed,large].
proba P_pk_coll.
proba Adv_Outsider_CCA.
proba Adv_Outsider_Auth.
fun kemkey2bitstr(kemkey_t): bitstring [data].
fun kemciph2bitstr(kemciph_t): bitstring [data].
expand Authenticated_KEM(keypairseed_t, pkey_t, skey_t, kemseed_t, AuthEncap_res_t, AuthDecap_res_t, kemkey_t, kemciph_t, skgen, pkgen, GenerateKeyPair, AuthEncap, AuthEncap_r, AuthEncap_key_r, AuthEncap_enc_r, AuthEncap_tuple, AuthEncap_None, AuthDecap, AuthDecap_Some, AuthDecap_None, P_pk_coll).
expand Outsider_CCA_Secure_Authenticated_KEM(keypairseed_t, pkey_t, skey_t, kemseed_t, AuthEncap_res_t, AuthDecap_res_t, kemkey_t, kemciph_t, skgen, pkgen, GenerateKeyPair, AuthEncap, AuthEncap_r, AuthEncap_key_r, AuthEncap_enc_r, AuthEncap_tuple, AuthEncap_None, AuthDecap, AuthDecap_Some, AuthDecap_None, Adv_Outsider_CCA).
expand Outsider_Auth_Secure_Authenticated_KEM(keypairseed_t, pkey_t, skey_t, kemseed_t, AuthEncap_res_t, AuthDecap_res_t, kemkey_t, kemciph_t, skgen, pkgen, GenerateKeyPair, AuthEncap, AuthEncap_r, AuthEncap_key_r, AuthEncap_enc_r, AuthEncap_tuple, AuthEncap_None, AuthDecap, AuthDecap_Some, AuthDecap_None, Adv_Outsider_Auth).
(* Analysing the HPKE Standard - Supplementary Material
Joël Alwen; Bruno Blanchet; Eduard Hauck; Eike Kiltz; Benjamin Lipp;
Doreen Riepel
This is supplementary material accompanying the paper:
Joël Alwen, Bruno Blanchet, Eduard Hauck, Eike Kiltz, Benjamin Lipp,
and Doreen Riepel. Analysing the HPKE Standard. In Anne Canteaut and
Francois-Xavier Standaert, editors, Eurocrypt 2021, Lecture Notes in
Computer Science, pages 87-116, Zagreb, Croatia, October 2021. Springer.
Long version: https://eprint.iacr.org/2020/1499 *)
type key_t [large,fixed].
type nonce_t [large,fixed].
expand Xor(
nonce_t, (* the space on which xor operates *)
xor, (* name of the xor function *)
nonce_zero (* the bitstring consisting only of zeroes in nonce_t; also used for seq that starts at zero *)
).
(** KDF **)
type extract_t [fixed,large].
type keys_t [fixed,large].
type tuple_t [fixed,large].
expand random_split_2(
keys_t,
key_t,
nonce_t,
tuple_t,
concat,
split
).
proba Adv_PRF_KeySchedule.
expand multikey_PRF(
kemkey_t,
bitstring, (* info *)
keys_t,
KeySchedule_auth,
Adv_PRF_KeySchedule
).
(* An AEAD encryption algorithm *)
proba Adv_cpa.
proba Adv_ctxt.
expand multikey_AEAD(
(* types *)
key_t,
bitstring, (* plaintext *)
bitstring, (* ciphertext *)
bitstring, (* additional data *)
nonce_t,
(* functions *)
Seal_inner,
Open_inner,
injbot, (* injection from plaintext to bitstringbot:
injbot(plaintext): bitstringbot *)
Length, (* returns a plaintext of same length, consisting of zeros:
Length(plaintext): plaintext *)
(* probabilities *)
Adv_cpa,
Adv_ctxt
).
letfun Seal(key: key_t, nonce: nonce_t, aad: bitstring, pt: bitstring) =
Seal_inner(pt, aad, key, nonce).
letfun Open(key: key_t, nonce: nonce_t, aad: bitstring, ct: bitstring) =
Open_inner(ct, aad, key, nonce).
(* Encryption Context *)
type context_t [large,fixed].
(* key, nonce, seq *)
fun Context(key_t, nonce_t, nonce_t): context_t [data].
expand OptionType_1(KeySchedule_res_t, KeySchedule_Some, KeySchedule_None, context_t).
letfun KeySchedule(shared_secret: kemkey_t, info: bitstring) =
let concat(key: key_t, nonce: nonce_t) =
split(KeySchedule_auth(shared_secret, info)) in (
KeySchedule_Some(Context(key, nonce, nonce_zero))
) else (
KeySchedule_None
).
(* Authentication using an Asymmetric Key *)
expand OptionType_2(SetupAuthS_res_t, SetupAuthS_Some, SetupAuthS_None, kemciph_t, context_t).
letfun SetupAuthS(pkR: pkey_t, info: bitstring, skS: skey_t) =
let AuthEncap_tuple(shared_secret: kemkey_t, enc: kemciph_t) = AuthEncap(pkR, skS) in
(
let KeySchedule_Some(ctx: context_t) = KeySchedule(shared_secret, info) in
(
SetupAuthS_Some(enc, ctx)
) else (
SetupAuthS_None
)
) else (
SetupAuthS_None
).
expand OptionType_1(SetupAuthR_res_t, SetupAuthR_Some, SetupAuthR_None, context_t).
letfun SetupAuthR(enc: kemciph_t, skR: skey_t, info: bitstring, pkS: pkey_t) =
let AuthDecap_Some(shared_secret: kemkey_t) = AuthDecap(enc, skR, pkS) in
(
let KeySchedule_Some(ctx: context_t) = KeySchedule(shared_secret, info) in
(
SetupAuthR_Some(ctx)
) else (
SetupAuthR_None
)
) else (
SetupAuthR_None
).
(* Encryption and Decryption *)
letfun Context_Nonce(nonce: nonce_t, seq: nonce_t) =
(* We suppose that seq has already the length of the nonce, by
assigning it the type nonce_t. *)
xor(nonce, seq).
expand OptionType_1(Context_Seal_res_t, Context_Seal_Some, Context_Seal_None, bitstring).
letfun Context_Seal(context: context_t, aad: bitstring,
pt: bitstring) =
let Context(key: key_t, nonce: nonce_t, seq: nonce_t) = context in
(
let ct: bitstring = Seal(key, Context_Nonce(nonce, seq), aad, pt) in
(* We consider a single message, so we do not need to model the increment of seq *)
Context_Seal_Some(ct)
) else (
Context_Seal_None
).
expand OptionType_1(Context_Open_res_t, Context_Open_Some, Context_Open_None, bitstring).
letfun Context_Open(context: context_t, aad: bitstring,
ct: bitstring) =
let Context(key: key_t, nonce: nonce_t, seq: nonce_t) = context in
(
let injbot(pt: bitstring) = Open(key, Context_Nonce(nonce, seq),
aad, ct) in
(
(* We consider a single message, so we do not need to model the increment of seq *)
Context_Open_Some(pt)
) else (
Context_Open_None
)
) else (
Context_Open_None
).
(* Single-Shot APIs *)
expand OptionType_2(SealAuth_res_t, SealAuth_Some, SealAuth_None, kemciph_t, bitstring).
letfun SealAuth(pkR: pkey_t, info: bitstring, aad: bitstring,
pt: bitstring, skS: skey_t) =
let SetupAuthS_Some(enc: kemciph_t, ctx: context_t) =
SetupAuthS(pkR, info, skS) in
(
let Context_Seal_Some(ct: bitstring) = Context_Seal(ctx, aad, pt) in
(
SealAuth_Some(enc, ct)
) else (
SealAuth_None
)
) else (
SealAuth_None
).
expand OptionType_1(OpenAuth_res_t, OpenAuth_Some, OpenAuth_None, Context_Open_res_t).
letfun OpenAuth(enc: kemciph_t, skR: skey_t, info_hash: bitstring,
aad: bitstring, ct: bitstring, pkS: pkey_t) =
let SetupAuthR_Some(ctx: context_t) =
SetupAuthR(enc, skR, info_hash, pkS) in
(
OpenAuth_Some(Context_Open(ctx, aad, ct))
) else (
OpenAuth_None
).
(* a set E used within the proof,
containing 6-tuples of the following type: *)
table E(
pkey_t, (* sender's public key *)
pkey_t, (* receiver's public key *)
kemciph_t, (* KEM ciphertext *)
bitstring, (* AEAD ciphertext *)
bitstring, (* AEAD additional authenticated data *)
bitstring (* application info string *)
).
param N. (* number of honest keypairs/users *)
param Qeperuser. (* number of calls to the Oaenc() oracle per keypair *)
param Qdperuser. (* number of calls to the Oadec() oracle per keypair *)
(* The proof goal is to prove that the adversary cannot produce inputs
such that the event adv_wins is executed. *)
event adv_wins.
query event(adv_wins).
process
(* The adversary can generate up to N honest keypairs/users by calling
the Osetup() oracle. The nested oracles Oaenc() and Oadec()
will be available for each honest keypair. *)
(foreach i <= N do
Osetup() :=
let (the_sk: skey_t, the_pk: pkey_t) = GenerateKeyPair() in
(* The public key of each honest keypair is made available
to the adversary. *)
return(the_pk);
(* This block defines the oracles Oaenc() and Oadec() which
are available for each honest keypair. *)
(
(* This defines the Oaenc() oracle with up to Qeperuser calls per keypair *)
(foreach iae <= Qeperuser do
Oaenc(pk: pkey_t, m: bitstring, aad: bitstring, info: bitstring) :=
let SealAuth_Some(enc: kemciph_t, ct: bitstring) =
SealAuth(pk, info, aad, m, the_sk) in (
insert E(the_pk, pk, enc, ct, aad, info);
return(SealAuth_Some(enc, ct))
) else (
return(SealAuth_None)
)
) |
(* This defines the Oadec() oracle with up to Qdperuser calls per keypair *)
(foreach iad <= Qdperuser do
Oadec(pk: pkey_t, enc: kemciph_t, c: bitstring, aad: bitstring, info: bitstring) :=
return(OpenAuth(enc, the_sk, info, aad, c, pk))
)
) (* End of the block defining Oaenc() and Oadec() *)
) (* End of the block defining Osetup() *)
|
(* The adversary can make one call to the challenge oracle. *)
Ochall(pk_S: pkey_t, pk_R: pkey_t, enc_star: kemciph_t,
ciph_star: bitstring, aad_star: bitstring, info_star: bitstring) :=
(* only accept pk_S, pk_R such that they are honest public keys *)
find i' <= N, i'' <= N suchthat
defined(the_pk[i'], the_pk[i''], the_sk[i'], the_sk[i''])
&& the_pk[i'] = pk_S
&& the_pk[i''] = pk_R then (
get E(=pk_S, =pk_R, =enc_star, =ciph_star, =aad_star, =info_star) in (
return(bottom)
) else (
let OpenAuth_Some(Context_Open_Some(pt: bitstring)) =
OpenAuth(enc_star, the_sk[i''], info_star, aad_star, ciph_star, pk_S) in (
event_abort adv_wins
) else return(bottom)
)
) else return(bottom)
(* EXPECTED FILENAME: examples/hpke/hpke.auth.outsider-auth.m4.ocv TAG: 1
All queries proved.
0.696s (user 0.692s + system 0.004s), max rss 33280K
END *)