2021-10-27 13:07:13 -07:00
|
|
|
#!/usr/bin/python3
|
|
|
|
|
2021-10-29 10:32:58 -07:00
|
|
|
# The maximum number of signatures verified by each transaction in the group.
|
2021-10-27 13:07:13 -07:00
|
|
|
# the total count of required transactions to verify all guardian signatures is
|
|
|
|
#
|
|
|
|
# floor(guardian_count / SIGNATURES_PER_TRANSACTION)
|
|
|
|
#
|
2021-10-29 10:32:58 -07:00
|
|
|
from pyteal.types import *
|
|
|
|
from pyteal.ast import *
|
2022-01-21 06:37:49 -08:00
|
|
|
MAX_SIGNATURES_PER_VERIFICATION_STEP = 8
|
2021-10-29 10:32:58 -07:00
|
|
|
|
|
|
|
"""
|
|
|
|
Math ceil function.
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
@Subroutine(TealType.uint64)
|
|
|
|
def ceil(n, d):
|
|
|
|
q = n / d
|
|
|
|
r = n % d
|
2021-10-29 07:17:35 -07:00
|
|
|
return Seq([
|
2021-10-29 10:32:58 -07:00
|
|
|
If(r != Int(0)).Then(Return(q + Int(1))).Else(Return(q))
|
2021-10-29 07:17:35 -07:00
|
|
|
])
|
|
|
|
|
2021-10-29 10:32:58 -07:00
|
|
|
|
|
|
|
"""
|
|
|
|
Return the minimum Uint64 of A,B
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
@Subroutine(TealType.uint64)
|
|
|
|
def min(a, b):
|
|
|
|
If(Int(a) < Int(b), Return(a), Return(b))
|
|
|
|
|
|
|
|
|
|
|
|
"""
|
|
|
|
Let G be the guardian count, N number of signatures per verification step, group must have CEIL(G/N) transactions.
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
@Subroutine(TealType.uint64)
|
|
|
|
def get_group_size(num_guardians):
|
|
|
|
return ceil(num_guardians, Int(MAX_SIGNATURES_PER_VERIFICATION_STEP))
|
|
|
|
|
|
|
|
|
|
|
|
"""
|
|
|
|
Get the number of signatures to verify in current step
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
@Subroutine(TealType.uint64)
|
|
|
|
def get_sig_count_in_step(step, num_guardians):
|
|
|
|
r = num_guardians % Int(MAX_SIGNATURES_PER_VERIFICATION_STEP)
|
|
|
|
return Seq(
|
|
|
|
If(r == Int(0)).Then(Return(Int(MAX_SIGNATURES_PER_VERIFICATION_STEP)))
|
|
|
|
.ElseIf(step < get_group_size(num_guardians) - Int(1))
|
|
|
|
.Then(
|
|
|
|
Return(Int(MAX_SIGNATURES_PER_VERIFICATION_STEP)))
|
|
|
|
.Else(
|
|
|
|
Return(num_guardians % Int(MAX_SIGNATURES_PER_VERIFICATION_STEP))))
|