-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathFinished.py
More file actions
33 lines (27 loc) · 1.08 KB
/
Finished.py
File metadata and controls
33 lines (27 loc) · 1.08 KB
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
import logging
from KeySchedule import KeySchedule
class Finished:
def __init__(self, key_sched: KeySchedule):
logging.basicConfig(level=logging.INFO)
self.key_sched = key_sched
self.expected_verify_data = None
def set_expected_verify_data(self):
# Calc the expected HMAC at client to validate server one
expected_verify_data = self.key_sched.hmacAlgo(
self.key_sched.get_s_finished(),
self.key_sched.hashAlgo(self.key_sched.transcript).digest()
).digest()
self.expected_verify_data = expected_verify_data
def do(self, msg):
"""
Parses the Finished message and extracts relevant fields.
"""
if self.expected_verify_data != msg:
raise ValueError("veryfy_data doesn't match with expected value: {}".format(msg))
return msg
def make(self):
verify_data = self.key_sched.hmacAlgo(
self.key_sched.get_c_finished(),
self.key_sched.hashAlgo(self.key_sched.transcript).digest(),
).digest()
return verify_data