-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsakura.py
84 lines (77 loc) · 2.61 KB
/
sakura.py
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
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from Crypto.Hash import keccak
from time import clock
def sakura(msg):
# Внутренняя функция RawSHAKE128 для построения древовидного режима (Keccak[c=256)(M||11))
def inner_func(mes):
keccak_hash = keccak.new(digest_bits=256)
mes = bytes(mes, 'utf-8') + b'11'
keccak_hash.update(mes)
return keccak_hash.hexdigest()
# Разбиение на пары:
def chunks(x, n):
for i in range(0, len(x), n):
yield x[i:i + n]
# Построение самого дерева через внутреннюю функцию:
def m_tree(x):
sub_t = []
for i in chunks(x, 2):
if len(i) == 2:
h = inner_func(i[0])+inner_func(i[1])
else:
h = inner_func(i[0])
sub_t.append(h)
if len(sub_t) == 1:
return sub_t[0]
else:
return m_tree(sub_t)
B = 128
M = [msg[i:i+B] for i in range(0, len(msg), B)]
S = []
l = 0
m_prev = len(M)
j_prev = len(bin(m_prev)[2:])
# Простановка первых нескольких меток:
for i in range(0, 2**(j_prev-1)):
p = bin(i)[2:]
label = (j_prev - len(p)) * '0' + p
S.append(label)
if m_prev == 2**(j_prev - 1):
m_cur = 0
else:
m_cur = 2
# Указатель позиции для добавления элемента в словарь:
pointer = 2**(j_prev-1)
# Проверка на избежание коллизий меток:
checker = ''
while m_cur > 1:
l += 1
m_cur = m_prev - 2**(j_prev-1)
j_cur = len(bin(m_cur)[2:])
s_1 = 2**(j_prev - 1)
s_2 = s_1 + 2**(j_cur - 1) - 1
index = 0
for i in range(s_1, s_2 + 1):
p = bin(index)[2:]
if j_cur == 1:
label = l * '1'
else:
label = '1' * l + (j_cur - len(p)) * '0' + p
if (len(checker) <= len(label)) and (l > 1):
label = '1' * l + (j_cur - len(p) - 1) * '0' + p
S.append(label)
index += 1
if pointer + 1 < len(M):
pointer += 1
checker = M[pointer - 1]
m_prev = m_cur
j_prev = j_cur
return m_tree(list(dict(zip(S, M)).values()))
ct = clock()
m = "kljxvcxjvopdgodmfopkokljxvcxjvvkodfdpbjvpocjbpdkvopxkvkcopopdgod" \
"mfopkopdkvopxkvkcopvkxcovkopbjvpocjbpgfdgdfvopvkxcofkopbfjvpocgg"*2**15
print(len(m))
s = sakura(m)
print(clock() - ct)
print(s)