2017-06-02 17:49:03 +03:00
|
|
|
from hashlib import sha1
|
|
|
|
|
2017-05-21 14:02:54 +03:00
|
|
|
from .. import helpers as utils
|
2017-06-09 17:13:39 +03:00
|
|
|
from ..extensions import BinaryReader, BinaryWriter
|
2016-08-28 20:26:06 +03:00
|
|
|
|
|
|
|
|
|
|
|
class AuthKey:
|
2016-09-08 17:11:37 +03:00
|
|
|
def __init__(self, data):
|
|
|
|
self.key = data
|
2016-08-28 20:26:06 +03:00
|
|
|
|
2017-06-02 17:49:03 +03:00
|
|
|
with BinaryReader(sha1(self.key).digest()) as reader:
|
2016-08-28 20:26:06 +03:00
|
|
|
self.aux_hash = reader.read_long(signed=False)
|
|
|
|
reader.read(4)
|
|
|
|
self.key_id = reader.read_long(signed=False)
|
|
|
|
|
|
|
|
def calc_new_nonce_hash(self, new_nonce, number):
|
2017-09-04 18:10:04 +03:00
|
|
|
"""Calculates the new nonce hash based on
|
|
|
|
the current class fields' values
|
|
|
|
"""
|
2016-08-28 20:26:06 +03:00
|
|
|
with BinaryWriter() as writer:
|
|
|
|
writer.write(new_nonce)
|
|
|
|
writer.write_byte(number)
|
|
|
|
writer.write_long(self.aux_hash, signed=False)
|
|
|
|
|
2016-09-08 17:11:37 +03:00
|
|
|
new_nonce_hash = utils.calc_msg_key(writer.get_bytes())
|
2016-08-28 20:26:06 +03:00
|
|
|
return new_nonce_hash
|