Academy

Use a Multi-Signature Scheme

Learn how to use multi-signature schemes to secure cross-chain communication.

Let's explore the use of a Multi-Signature Scheme. We'll take the following steps:

  • Generate Two Key Pairs: We will generate two key pairs.
  • Sign Message: We create two Signatures of the same Message with the two Secret Keys.
  • Aggregate Signatures: We aggregate the two Signatures to a single Signature.
  • Aggregate Public Keys: We aggregate the two Public Keys to a single Public Key.
  • Verify aggregated Signature: We verify the Signature with the aggregated Public Key.

Generate First Key

Start by generating a Key Pair consisting of a Public and Secret Key.

Sign the Messages

Now use the generated Secret Key to sign a Message.

Enter private key to sign message with

Enter any Message you want to sign with the Private Key

Generate Second Key

In a real-world setting these key pairs would be created by independent actors, but for the sake of the exercise we will play multiple actors here.

Sign the Message with the second Key

Make sure to pick exactly the same Message for both Signatures, e.g. "Per consensum ad astra".

Enter private key to sign message with

Enter any Message you want to sign with the Private Key

Aggregate Signatures

We can now utilize the signature aggregation to create an aggregated Signature. In this exercise we are only aggregating two signatures, but we could do this with hundreds or thousands. Side fact: It does not matter in which order the signatures are aggrated.

Enter the first Signature of the Message.

Enter the second Signature of the Message.

Aggregate Public Keys

To verify an aggregated Signature, we also need to aggregate the Public Keys that correspond to the Private Keys that were used to sign the message. Analogous to the signatures we can aggregate many more than just two Public Keys and also here the order does not matter.

Enter the first Public Key to aggregate.

Enter the second Public Key to aggregate.

Verify the Aggregated Signature

Anyone, that has access to the aggregated Public Key can now verify the Signature of the Message. Therefore, the Authenticity, Non-Repudiation and Integrity of the Message can be trusted in an efficient way for a large number of signers.

Enter the Public Key that signed the Message.

Enter the Message that was signed.

Enter the Signature of the Message.

Congrats on going through the exercise and experiencing hands-on how we can utilize Signature Aggregation. You will see in the next chapter about Avalanche Warp Messaging; how Mutli-Signature schemes can enable secure and efficient cross-L1 communication.

Edit on GitHub

Last updated on