Compare commits

3 Commits

Author SHA1 Message Date
a10144f05d Merge pull request 'main' (#11) from sangge/mimajingsai:main into main
Reviewed-on: #11
2023-10-17 23:18:52 +08:00
c0494494a7 feat: finish demo 2023-10-17 23:00:28 +08:00
9e8760e5d9 feat: add point type and capsule type 2023-10-17 22:40:17 +08:00
2 changed files with 66 additions and 35 deletions

View File

@@ -1,3 +1,31 @@
from tpre import * from tpre import *
# 1
pk_a, sk_a = GenerateKeyPair(1, ())
m = b'hello world'
m = int.from_bytes(m)
# 2
capsule_ct = Encrypt(pk_a, m)
# 3
pk_b, sk_b = GenerateKeyPair(1, ())
N = 20
T = 10
# 5
rekeys = GenerateReKey(sk_a, pk_b, N, T)
# 7
cfrag_cts = []
for rekey in rekeys:
cfrag_ct = ReEncrypt(rekey, capsule_ct)
cfrag_cts.append(cfrag_ct)
# 9
cfrags = mergecfrag(cfrag_cts)
m = DecryptFrags(sk_b, pk_b, pk_a, cfrags)

View File

@@ -2,6 +2,9 @@ from gmssl import * #pylint: disable = e0401
from typing import Tuple, Callable from typing import Tuple, Callable
import random import random
point = Tuple[int, int]
capsule = Tuple[point, point, int]
# 生成密钥对模块 # 生成密钥对模块
class CurveFp: class CurveFp:
def __init__(self, A, B, P, N, Gx, Gy, name): def __init__(self, A, B, P, N, Gx, Gy, name):
@@ -29,13 +32,13 @@ G = sm2p256v1
# 生成元 # 生成元
g = (sm2p256v1.Gx, sm2p256v1.Gy) g = (sm2p256v1.Gx, sm2p256v1.Gy)
def multiply(a: Tuple[int, int], n: int) -> Tuple[int, int]: def multiply(a: point, n: int) -> point:
N = sm2p256v1.N N = sm2p256v1.N
A = sm2p256v1.A A = sm2p256v1.A
P = sm2p256v1.P P = sm2p256v1.P
return fromJacobian(jacobianMultiply(toJacobian(a), n, N, A, P), P) return fromJacobian(jacobianMultiply(toJacobian(a), n, N, A, P), P)
def add(a: Tuple[int, int], b: Tuple[int, int]) -> Tuple[int, int]: def add(a: point, b: point) -> point:
A = sm2p256v1.A A = sm2p256v1.A
P = sm2p256v1.P P = sm2p256v1.P
return fromJacobian(jacobianAdd(toJacobian(a), toJacobian(b), A, P), P) return fromJacobian(jacobianAdd(toJacobian(a), toJacobian(b), A, P), P)
@@ -51,11 +54,11 @@ def inv(a: int, n: int) -> int:
lm, low, hm, high = nm, new, lm, low lm, low, hm, high = nm, new, lm, low
return lm % n return lm % n
def toJacobian(Xp_Yp: Tuple[int, int]) -> Tuple[int, int, int]: def toJacobian(Xp_Yp: point) -> Tuple[int, int, int]:
Xp, Yp = Xp_Yp Xp, Yp = Xp_Yp
return (Xp, Yp, 1) return (Xp, Yp, 1)
def fromJacobian(Xp_Yp_Zp: Tuple[int, int, int], P: int) -> Tuple[int, int]: def fromJacobian(Xp_Yp_Zp: Tuple[int, int, int], P: int) -> point:
Xp, Yp, Zp = Xp_Yp_Zp Xp, Yp, Zp = Xp_Yp_Zp
z = inv(Zp, P) z = inv(Zp, P)
return ((Xp * z ** 2) % P, (Yp * z ** 3) % P) return ((Xp * z ** 2) % P, (Yp * z ** 3) % P)
@@ -126,7 +129,7 @@ def jacobianMultiply(
# 生成元 # 生成元
U = multiply(g, random.randint(0, sm2p256v1.P)) U = multiply(g, random.randint(0, sm2p256v1.P))
def hash2(double_G: Tuple[Tuple[int, int], Tuple[int, int]]) -> int: def hash2(double_G: Tuple[point, point]) -> int:
sm3 = Sm3() #pylint: disable=e0602 sm3 = Sm3() #pylint: disable=e0602
for i in double_G: for i in double_G:
for j in i: for j in i:
@@ -135,9 +138,9 @@ def hash2(double_G: Tuple[Tuple[int, int], Tuple[int, int]]) -> int:
digest = int.from_bytes(digest,'big') % sm2p256v1.P digest = int.from_bytes(digest,'big') % sm2p256v1.P
return digest return digest
def hash3(triple_G: Tuple[Tuple[int, int], def hash3(triple_G: Tuple[point,
Tuple[int, int], point,
Tuple[int, int]]) -> int: point]) -> int:
sm3 = Sm3() #pylint: disable=e0602 sm3 = Sm3() #pylint: disable=e0602
for i in triple_G: for i in triple_G:
for j in i: for j in i:
@@ -146,9 +149,9 @@ def hash3(triple_G: Tuple[Tuple[int, int],
digest = int.from_bytes(digest, 'big') % sm2p256v1.P digest = int.from_bytes(digest, 'big') % sm2p256v1.P
return digest return digest
def hash4(triple_G: Tuple[Tuple[int, int], def hash4(triple_G: Tuple[point,
Tuple[int, int], point,
Tuple[int, int]], point],
Zp: int) -> int: Zp: int) -> int:
sm3 = Sm3() #pylint: disable=e0602 sm3 = Sm3() #pylint: disable=e0602
for i in triple_G: for i in triple_G:
@@ -159,7 +162,7 @@ def hash4(triple_G: Tuple[Tuple[int, int],
digest = int.from_bytes(digest, 'big') % sm2p256v1.P digest = int.from_bytes(digest, 'big') % sm2p256v1.P
return digest return digest
def KDF(G: Tuple[int, int]) -> int: def KDF(G: point) -> int:
sm3 = Sm3() #pylint: disable=e0602 sm3 = Sm3() #pylint: disable=e0602
for i in G: for i in G:
sm3.update(i.to_bytes(32)) sm3.update(i.to_bytes(32))
@@ -171,7 +174,7 @@ def KDF(G: Tuple[int, int]) -> int:
def GenerateKeyPair( def GenerateKeyPair(
lamda_parma: int, lamda_parma: int,
public_params: tuple public_params: tuple
) -> Tuple[Tuple[int, int], int]: ) -> Tuple[point, int]:
''' '''
params: params:
lamda_param: an init safety param lamda_param: an init safety param
@@ -196,8 +199,8 @@ def GenerateKeyPair(
#pk_A, sk_A = GenerateKeyPair(0, ()) #pk_A, sk_A = GenerateKeyPair(0, ())
#pk_B, sk_B = GenerateKeyPair(0, ()) #pk_B, sk_B = GenerateKeyPair(0, ())
def Encrypt(pk: Tuple[int, int], m: int) -> Tuple[Tuple[ def Encrypt(pk: point, m: int) -> Tuple[Tuple[
Tuple[int, int],Tuple[int, int], int], int]: point,point, int], int]:
enca = Encapsulate(pk) enca = Encapsulate(pk)
K = enca[0].to_bytes() K = enca[0].to_bytes()
capsule = enca[1] capsule = enca[1]
@@ -211,7 +214,7 @@ def Encrypt(pk: Tuple[int, int], m: int) -> Tuple[Tuple[
enc_message = (capsule, enc_Data) enc_message = (capsule, enc_Data)
return enc_message return enc_message
def Decapsulate(ska:int,capsule:Tuple[Tuple[int,int],Tuple[int,int],int]) -> int: def Decapsulate(ska:int,capsule:capsule) -> int:
E,V,s = capsule E,V,s = capsule
EVa=multiply(add(E,V), ska) # (E*V)^ska EVa=multiply(add(E,V), ska) # (E*V)^ska
K = KDF(EVa) K = KDF(EVa)
@@ -219,7 +222,7 @@ def Decapsulate(ska:int,capsule:Tuple[Tuple[int,int],Tuple[int,int],int]) -> int
return K return K
def Decrypt(sk_A: int,C:Tuple[Tuple[ def Decrypt(sk_A: int,C:Tuple[Tuple[
Tuple[int, int],Tuple[int, int], int], int]) ->int: point, point, int], int]) ->int:
''' '''
params: params:
sk_A: secret key sk_A: secret key
@@ -242,9 +245,9 @@ def hash5(id: int, D: int) -> int:
hash = int.from_bytes(hash,'big') % G.P hash = int.from_bytes(hash,'big') % G.P
return hash return hash
def hash6(triple_G: Tuple[Tuple[int, int], def hash6(triple_G: Tuple[point,
Tuple[int, int], point,
Tuple[int, int]]) -> int: point]) -> int:
sm3 = Sm3() #pylint: disable=e0602 sm3 = Sm3() #pylint: disable=e0602
for i in triple_G: for i in triple_G:
for j in i: for j in i:
@@ -262,7 +265,7 @@ def f(x: int, f_modulus: list, T: int) -> int:
res += f_modulus[i] * pow(x, i) res += f_modulus[i] * pow(x, i)
return res return res
def GenerateReKey(sk_A, pk_B, N: int, T: int) -> list: def GenerateReKey(sk_A: int, pk_B: point, N: int, T: int) -> list:
''' '''
param: param:
skA, pkB, N(节点总数), T(阈值) skA, pkB, N(节点总数), T(阈值)
@@ -301,7 +304,7 @@ def GenerateReKey(sk_A, pk_B, N: int, T: int) -> list:
return KF return KF
def Encapsulate(pk_A: Tuple[int, int]) -> Tuple[int, Tuple[Tuple[int, int], Tuple[int, int], int]]: def Encapsulate(pk_A: point) -> Tuple[int, capsule]:
r = random.randint(0, G.P - 1) r = random.randint(0, G.P - 1)
u = random.randint(0, G.P - 1) u = random.randint(0, G.P - 1)
E = multiply(g, r) E = multiply(g, r)
@@ -312,7 +315,7 @@ def Encapsulate(pk_A: Tuple[int, int]) -> Tuple[int, Tuple[Tuple[int, int], Tupl
capsule = (E, V, s) capsule = (E, V, s)
return (K, capsule) return (K, capsule)
def Checkcapsule(capsule:Tuple[Tuple[int,int],Tuple[int,int],int]) -> bool: # 验证胶囊的有效性 def Checkcapsule(capsule:capsule) -> bool: # 验证胶囊的有效性
E,V,s = capsule E,V,s = capsule
h2 = hash2((E,V)) h2 = hash2((E,V))
g = (sm2p256v1.Gx, sm2p256v1.Gy) g = (sm2p256v1.Gx, sm2p256v1.Gy)
@@ -326,7 +329,7 @@ def Checkcapsule(capsule:Tuple[Tuple[int,int],Tuple[int,int],int]) -> bool: #
return flag return flag
def ReEncapsulate(kFrag:list,capsule:Tuple[Tuple[int,int],Tuple[int,int],int]) -> Tuple[Tuple[int,int],Tuple[int,int],int,Tuple[int,int]] : def ReEncapsulate(kFrag:list,capsule:capsule) -> Tuple[point,point,int,point] :
id,rk,Xa,U1 = kFrag id,rk,Xa,U1 = kFrag
E,V,s = capsule E,V,s = capsule
if not Checkcapsule(capsule): if not Checkcapsule(capsule):
@@ -340,7 +343,7 @@ def ReEncapsulate(kFrag:list,capsule:Tuple[Tuple[int,int],Tuple[int,int],int]) -
# 重加密函数 # 重加密函数
def ReEncrypt(kFrag:list, def ReEncrypt(kFrag:list,
C:Tuple[Tuple[Tuple[int,int],Tuple[int,int],int],int])->Tuple[Tuple[Tuple[int,int],Tuple[int,int],int,Tuple[int,int]],int] : C:Tuple[capsule,int])->Tuple[Tuple[point,point,int,point],int] :
capsule,enc_Data = C capsule,enc_Data = C
cFrag = ReEncapsulate(kFrag,capsule) cFrag = ReEncapsulate(kFrag,capsule)
@@ -349,9 +352,9 @@ def ReEncrypt(kFrag:list,
# N 是加密节点的数量t是阈值 # N 是加密节点的数量t是阈值
def mergecfrag(sk_A: int, pk_A: Tuple[int, int], pk_B: Tuple[int, int], def mergecfrag(sk_A: int, pk_A: point, pk_B: point,
N: int, t: int)->tuple[Tuple[Tuple[int,int],Tuple[int,int] N: int, t: int)->tuple[Tuple[point,point
,int,Tuple[int,int]], ...]: ,int,point], ...]:
cfrags = () cfrags = ()
kfrags = GenerateReKey(sk_A,pk_B,N,t) kfrags = GenerateReKey(sk_A,pk_B,N,t)
result = Encapsulate(pk_A) result = Encapsulate(pk_A)
@@ -365,9 +368,9 @@ def mergecfrag(sk_A: int, pk_A: Tuple[int, int], pk_B: Tuple[int, int],
def DecapsulateFrags(sk_B:int, def DecapsulateFrags(sk_B:int,
pk_B: Tuple[int, int], pk_B: point,
pk_A:Tuple[int,int], pk_A:point,
cFrags:Tuple[Tuple[Tuple[int,int],Tuple[int,int],int,Tuple[int,int]]] cFrags:Tuple[Tuple[point,point,int,point]]
) -> int: ) -> int:
''' '''
return: return:
@@ -421,10 +424,10 @@ def DecapsulateFrags(sk_B:int,
# M = IAEAM(K,enc_Data) # M = IAEAM(K,enc_Data)
def DecryptFrags(sk_B: int, def DecryptFrags(sk_B: int,
pk_B: Tuple[int, int], pk_B: point,
pk_A: Tuple[int,int], pk_A: point,
cFrags: Tuple[Tuple[Tuple[int,int],Tuple[int,int],int,Tuple[int,int]]], cFrags: Tuple[Tuple[point,point,int,point]],
C: Tuple[Tuple[Tuple[int,int],Tuple[int,int],int],int] C: Tuple[capsule,int]
) -> int: ) -> int:
capsule,enc_Data = C # 加密后的密文 capsule,enc_Data = C # 加密后的密文
K = DecapsulateFrags(sk_B, pk_B, pk_A,cFrags) K = DecapsulateFrags(sk_B, pk_B, pk_A,cFrags)