blob: 3bc918d4387686f67d35fa3bd288187c9fb85959 (
plain)
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
|
(herald "Yahalom Protocol with Forwarding Removed")
(defprotocol yahalom basic
(defrole init
(vars (a b c name) (n-a n-b text) (k skey))
(trace (send (cat a n-a))
(recv (enc b k n-a n-b (ltk a c)))
(send (enc n-b k))))
(defrole resp
(vars (b a c name) (n-a n-b text) (k skey))
(trace (recv (cat a n-a))
(send (cat b (enc a n-a n-b (ltk b c))))
(recv (enc a k (ltk b c)))
(recv (enc n-b k))))
(defrole serv
(vars (c a b name) (n-a n-b text) (k skey))
(trace (recv (cat b (enc a n-a n-b (ltk b c))))
(send (enc b k n-a n-b (ltk a c)))
(send (enc a k (ltk b c))))
(uniq-orig k)))
(defskeleton yahalom
(vars (a b c name) (n-b text))
(defstrand resp 4 (a a) (b b) (c c) (n-b n-b))
(non-orig (ltk b c) (ltk a c))
(uniq-orig n-b))
;;; Ensure encryption key remains secret.
(defskeleton yahalom
(vars (a b c name) (n-b text) (k skey))
(defstrand resp 4 (a a) (b b) (c c) (n-b n-b) (k k))
(deflistener k)
(non-orig (ltk b c) (ltk a c))
(uniq-orig n-b))
|