add rust implementation
	
		
			
	
		
	
	
		
	
		
			All checks were successful
		
		
	
	
		
			
				
	
				Test CI / test speed (push) Successful in 15s
				
					
					
				
			
		
		
	
	
				
					
				
			
		
			All checks were successful
		
		
	
	Test CI / test speed (push) Successful in 15s
				This commit is contained in:
		
							
								
								
									
										14
									
								
								src/tpre.py
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								src/tpre.py
									
									
									
									
									
								
							| @@ -1,6 +1,7 @@ | |||||||
| from gmssl import Sm3, Sm2Key, Sm4Cbc, DO_ENCRYPT, DO_DECRYPT | from gmssl import Sm3, Sm2Key, Sm4Cbc, DO_ENCRYPT, DO_DECRYPT | ||||||
| from typing import Tuple | from typing import Tuple | ||||||
| import random | import random | ||||||
|  | import ecc_rs | ||||||
|  |  | ||||||
| point = Tuple[int, int] | point = Tuple[int, int] | ||||||
| capsule = Tuple[point, point, int] | capsule = Tuple[point, point, int] | ||||||
| @@ -33,14 +34,23 @@ sm2p256v1 = CurveFp( | |||||||
| g = (sm2p256v1.Gx, sm2p256v1.Gy) | g = (sm2p256v1.Gx, sm2p256v1.Gy) | ||||||
|  |  | ||||||
|  |  | ||||||
| def multiply(a: point, n: int) -> point: | def multiply(a: point, n: int, flag: int = 0) -> point: | ||||||
|  |     if flag == 1: | ||||||
|  |  | ||||||
|  |         result = ecc_rs.multiply(a, n) | ||||||
|  |         return result | ||||||
|  |     else: | ||||||
|         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: point, b: point) -> point: | def add(a: point, b: point, flag: int = 0) -> point: | ||||||
|  |     if flag == 1: | ||||||
|  |         result = ecc_rs.add(a, b) | ||||||
|  |         return result | ||||||
|  |     else: | ||||||
|         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) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user