You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

53 lines
1.3 KiB

  1. import unittest, operator
  2. load("ring-signatures.sage")
  3. # ethereum elliptic curve
  4. p = 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEFFFFFC2F
  5. a = 0
  6. b = 7
  7. F = GF(p)
  8. E = EllipticCurve(F, [a,b])
  9. GX = 0x79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798
  10. GY = 0x483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8
  11. g = E(GX,GY)
  12. n = 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141
  13. h = 1
  14. q = g.order()
  15. assert is_prime(p)
  16. assert is_prime(q)
  17. assert g * q == 0
  18. class TestRingSignatures(unittest.TestCase):
  19. def test_blSAG_ring_of_5(self):
  20. test_blSAG(5, 3)
  21. def test_blSAG_ring_of_20(self):
  22. test_blSAG(20, 14)
  23. def test_blSAG(ring_size, pi):
  24. print(f"[blSAG] Testing with a ring of {ring_size} keys")
  25. prover = Prover(F, g)
  26. n = ring_size
  27. R = [None] * n
  28. # generate prover's key pair
  29. K_pi = prover.new_key()
  30. # generate other n public keys
  31. for i in range(0, n):
  32. R[i] = g * i
  33. # set K_pi
  34. R[pi] = K_pi
  35. # sign m
  36. m = 1234
  37. print("sign")
  38. sig = prover.sign(m, R)
  39. print("verify")
  40. key_image = prover.w * hashToPoint(prover.K)
  41. verify(g, R, m, key_image, sig)
  42. if __name__ == '__main__':
  43. unittest.main()