Exemplo n.º 1
0
    def test_vectors(self):
        sk1 = PrivateKey.from_seed(bytes([1, 2, 3, 4, 5]))
        pk1 = sk1.get_public_key()
        sig1 = sk1.sign(bytes([7, 8, 9]))

        sk2 = PrivateKey.from_seed(bytes([1, 2, 3, 4, 5, 6]))
        pk2 = sk2.get_public_key()
        sig2 = sk2.sign(bytes([7, 8, 9]))
        assert (sk1.serialize() == bytes.fromhex(
            "022fb42c08c12de3a6af053880199806532e79515f94e83461612101f9412f9e")
                )
        assert (pk1.get_fingerprint() == 0x26d53247)
        assert (pk2.get_fingerprint() == 0x289bb56e)
        assert (sig1.serialize() == bytes.fromhex(
            "93eb2e1cb5efcfb31f2c08b235e8203a67265bc6a13d9f0ab77727293b74a357ff0459ac210dc851fcb8a60cb7d393a419915cfcf83908ddbeac32039aaa3e8fea82efcb3ba4f740f20c76df5e97109b57370ae32d9b70d256a98942e5806065"
        ))
        assert (sig2.serialize() == bytes.fromhex(
            "975b5daa64b915be19b5ac6d47bc1c2fc832d2fb8ca3e95c4805d8216f95cf2bdbb36cc23645f52040e381550727db420b523b57d494959e0e8c0c6060c46cf173872897f14d43b2ac2aec52fc7b46c02c5699ff7a10beba24d3ced4e89c821e"
        ))

        agg_sig = BLS.aggregate_sigs([sig1, sig2])
        agg_pk = BLS.aggregate_pub_keys([pk1, pk2], True)
        agg_sk = BLS.aggregate_priv_keys([sk1, sk2], [pk1, pk2], True)
        assert (agg_sig.serialize() == bytes.fromhex(
            "0a638495c1403b25be391ed44c0ab013390026b5892c796a85ede46310ff7d0e0671f86ebe0e8f56bee80f28eb6d999c0a418c5fc52debac8fc338784cd32b76338d629dc2b4045a5833a357809795ef55ee3e9bee532edfc1d9c443bf5bc658"
        ))
        assert (agg_sk.sign(bytes([7, 8,
                                   9])).serialize() == agg_sig.serialize())

        assert (BLS.verify(sig1))
        assert (BLS.verify(agg_sig))

        agg_sig.set_aggregation_info(
            AggregationInfo.from_msg(agg_pk, bytes([7, 8, 9])))
        assert (BLS.verify(agg_sig))

        sig1.set_aggregation_info(sig2.aggregation_info)
        assert (not BLS.verify(sig1))

        sig3 = sk1.sign(bytes([1, 2, 3]))
        sig4 = sk1.sign(bytes([1, 2, 3, 4]))
        sig5 = sk2.sign(bytes([1, 2]))

        agg_sig2 = BLS.aggregate_sigs([sig3, sig4, sig5])
        assert (BLS.verify(agg_sig2))
        assert (agg_sig2.serialize() == bytes.fromhex(
            "8b11daf73cd05f2fe27809b74a7b4c65b1bb79cc1066bdf839d96b97e073c1a635d2ec048e0801b4a208118fdbbb63a516bab8755cc8d850862eeaa099540cd83621ff9db97b4ada857ef54c50715486217bd2ecb4517e05ab49380c041e159b"
        ))
Exemplo n.º 2
0
    def _test_threshold_instance(self, T, N):
        commitments = []
        # fragments[i][j] = fragment held by player i,
        #                   received from player j
        fragments = [[None] * N for _ in range(N)]
        secrets = []

        # Step 1 : PrivateKey.new_threshold
        for player in range(N):
            secret_key, commi, frags = PrivateKey.new_threshold(T, N)
            for target, frag in enumerate(frags):
                fragments[target][player] = frag
            commitments.append(commi)
            secrets.append(secret_key)

        # Step 2 : Threshold.verify_secret_fragment
        for player_source in range(1, N + 1):
            for player_target in range(1, N + 1):
                assert Threshold.verify_secret_fragment(
                    T, fragments[player_target - 1][player_source - 1],
                    player_target, commitments[player_source - 1])

        # Step 3 : master_pubkey = BLS.aggregate_pub_keys(...)
        #          secret_share = BLS.aggregate_priv_keys(...)
        master_pubkey = BLS.aggregate_pub_keys([
            PublicKey.from_g1(cpoly[0].to_jacobian()) for cpoly in commitments
        ], False)

        secret_shares = [
            BLS.aggregate_priv_keys(map(PrivateKey, row), None, False)
            for row in fragments
        ]

        master_privkey = BLS.aggregate_priv_keys(secrets, None, False)
        msg = 'Test'
        signature_actual = master_privkey.sign(msg)

        # Step 4 : sig_share = secret_share.sign_threshold(...)
        # Check every combination of T players
        for X in combinations(range(1, N + 1), T):
            # X: a list of T indices like [1, 2, 5]

            # Check underlying secret key is correct
            r = Threshold.interpolate_at_zero(
                X, [secret_shares[x - 1].value for x in X])
            secret_cand = PrivateKey(r)
            assert secret_cand == master_privkey

            # Check signatures
            signature_shares = [
                secret_shares[x - 1].sign_threshold(msg, x, X) for x in X
            ]
            signature_cand = BLS.aggregate_sigs_simple(signature_shares)
            assert signature_cand == signature_actual

        # Check that the signature actually verifies the message
        agg_info = AggregationInfo.from_msg(master_pubkey, msg)
        signature_actual.set_aggregation_info(agg_info)
        assert BLS.verify(signature_actual)

        # Step 4b : Alternatively, we can add the lagrange coefficients
        # to 'unit' signatures.
        for X in combinations(range(1, N + 1), T):
            # X: a list of T indices like [1, 2, 5]

            # Check signatures
            signature_shares = [secret_shares[x - 1].sign(msg) for x in X]
            signature_cand = Threshold.aggregate_unit_sigs(
                signature_shares, X, T)
            assert signature_cand == signature_actual
Exemplo n.º 3
0
    def test1(self):
        seed = bytes([
            0, 50, 6, 244, 24, 199, 1, 25, 52, 88, 192, 19, 18, 12, 89, 6, 220,
            18, 102, 58, 209, 82, 12, 62, 89, 110, 182, 9, 44, 20, 254, 22
        ])
        sk = PrivateKey.from_seed(seed)
        pk = sk.get_public_key()

        msg = bytes([100, 2, 254, 88, 90, 45, 23])

        sig = sk.sign(msg)

        sk_bytes = sk.serialize()
        pk_bytes = pk.serialize()
        sig_bytes = sig.serialize()

        sk = PrivateKey.from_bytes(sk_bytes)
        pk = PublicKey.from_bytes(pk_bytes)
        sig = Signature.from_bytes(sig_bytes)

        sig.set_aggregation_info(AggregationInfo.from_msg(pk, msg))
        assert (BLS.verify(sig))

        seed = bytes([1]) + seed[1:]
        sk1 = PrivateKey.from_seed(seed)
        seed = bytes([2]) + seed[1:]
        sk2 = PrivateKey.from_seed(seed)

        pk1 = sk1.get_public_key()
        sig1 = sk1.sign(msg)

        pk2 = sk2.get_public_key()
        sig2 = sk2.sign(msg)

        agg_sig = BLS.aggregate_sigs([sig1, sig2])
        agg_pubkey = BLS.aggregate_pub_keys([pk1, pk2], True)

        agg_sig.set_aggregation_info(AggregationInfo.from_msg(agg_pubkey, msg))
        assert (BLS.verify(agg_sig))

        seed = bytes([3]) + seed[1:]
        sk3 = PrivateKey.from_seed(seed)
        pk3 = sk3.get_public_key()
        msg2 = bytes([100, 2, 254, 88, 90, 45, 23])

        sig1 = sk1.sign(msg)
        sig2 = sk2.sign(msg)
        sig3 = sk3.sign(msg2)
        agg_sig_l = BLS.aggregate_sigs([sig1, sig2])
        agg_sig_final = BLS.aggregate_sigs([agg_sig_l, sig3])

        sig_bytes = agg_sig_final.serialize()

        agg_sig_final = Signature.from_bytes(sig_bytes)
        a1 = AggregationInfo.from_msg(pk1, msg)
        a2 = AggregationInfo.from_msg(pk2, msg)
        a3 = AggregationInfo.from_msg(pk3, msg2)
        a1a2 = AggregationInfo.merge_infos([a1, a2])
        a_final = AggregationInfo.merge_infos([a1a2, a3])
        print(a_final)
        agg_sig_final.set_aggregation_info(a_final)
        assert (BLS.verify(agg_sig_final))

        assert (BLS.verify(agg_sig_l))
        agg_sig_final = agg_sig_final.divide_by([agg_sig_l])

        assert (BLS.verify(agg_sig_final))

        agg_sk = BLS.aggregate_priv_keys([sk1, sk2], [pk1, pk2], True)
        agg_sk.sign(msg)

        seed = bytes([
            1, 50, 6, 244, 24, 199, 1, 25, 52, 88, 192, 19, 18, 12, 89, 6, 220,
            18, 102, 58, 209, 82, 12, 62, 89, 110, 182, 9, 44, 20, 254, 22
        ])

        esk = ExtendedPrivateKey.from_seed(seed)
        epk = esk.get_extended_public_key()

        sk_child = esk.private_child(0).private_child(5)
        pk_child = epk.public_child(0).public_child(5)

        assert (sk_child.get_extended_public_key() == pk_child)
Exemplo n.º 4
0
 def aggregate_private_shares(self):
     self.aggregated_private_key = BLS.aggregate_priv_keys(
         map(PrivateKey, [share[1] for share in self.private_shares]), None,
         False)
Exemplo n.º 5
0
def aggregate_private_shares(shares):
    return BLS.aggregate_priv_keys(map(PrivateKey, shares), None, False)