globals.py 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. #!/usr/bin/python3
  2. # The maximum number of signatures verified by each transaction in the group.
  3. # the total count of required transactions to verify all guardian signatures is
  4. #
  5. # floor(guardian_count / SIGNATURES_PER_TRANSACTION)
  6. #
  7. from pyteal.types import *
  8. from pyteal.ast import *
  9. MAX_SIGNATURES_PER_VERIFICATION_STEP = 8
  10. """
  11. Math ceil function.
  12. """
  13. @Subroutine(TealType.uint64)
  14. def ceil(n, d):
  15. q = n / d
  16. r = n % d
  17. return Seq([
  18. If(r != Int(0)).Then(Return(q + Int(1))).Else(Return(q))
  19. ])
  20. """
  21. Return the minimum Uint64 of A,B
  22. """
  23. @Subroutine(TealType.uint64)
  24. def min(a, b):
  25. If(Int(a) < Int(b), Return(a), Return(b))
  26. """
  27. Let G be the guardian count, N number of signatures per verification step, group must have CEIL(G/N) transactions.
  28. """
  29. @Subroutine(TealType.uint64)
  30. def get_group_size(num_guardians):
  31. return ceil(num_guardians, Int(MAX_SIGNATURES_PER_VERIFICATION_STEP))
  32. """
  33. Get the number of signatures to verify in current step
  34. """
  35. @Subroutine(TealType.uint64)
  36. def get_sig_count_in_step(step, num_guardians):
  37. r = num_guardians % Int(MAX_SIGNATURES_PER_VERIFICATION_STEP)
  38. return Seq(
  39. If(r == Int(0)).Then(Return(Int(MAX_SIGNATURES_PER_VERIFICATION_STEP)))
  40. .ElseIf(step < get_group_size(num_guardians) - Int(1))
  41. .Then(
  42. Return(Int(MAX_SIGNATURES_PER_VERIFICATION_STEP)))
  43. .Else(
  44. Return(num_guardians % Int(MAX_SIGNATURES_PER_VERIFICATION_STEP))))