Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Verifiable randomness #26

Open
szynwelski opened this issue May 22, 2023 · 5 comments
Open

Verifiable randomness #26

szynwelski opened this issue May 22, 2023 · 5 comments
Assignees
Milestone

Comments

@szynwelski
Copy link
Contributor

szynwelski commented May 22, 2023

The goal of the task is to implement the functionality of providing pseudorandom data to the contract. The current implementation of the functionality is described here.

The current solution has the drawback of relying on trust in the sequencer. The sequencer can manipulate the sortKey value, especially the timestamp, to obtain a desired value. However, we believe that it is not doing so. In the new solution, we cannot make that assumption because we assume that malicious nodes can exist in the network.

In the new solution, the evaluation of contract states can start after the production of a block by the sequencer network (the network guarantees that transactions will eventually be included in Arweave through a decentralized relayer mechanism #13). Therefore, it would be great if randomness could be generated by the proposer. However, the proposer cannot know the pseudorandom value at the time of block creation, as it would give them an opportunity for abuse. Therefore, this value must be computed after block finalization.

I see the following solutions that are resilient to malicious actions by 1/3 of the network nodes:

Using Bundlr signature
The VRF (Verifiable Random Function) data is calculated by the relayer. The relayer sends the block to Bundlr and receives a signed receipt. Then, it calculates the VRF data, where the input is the hash of the block, interaction ID, and the receipt signature.
➕ Cosmos nodes do not have the ability to cheat because randomness is based on an external trusted source
➖ next area (besides sending to Arweave) where we rely on Bundlr
➖ VRF data is calculated by the relayer only after sending the block to Arweave, this data also needs to be sent to Bundlr (either with the next block or independently), which complicates the sending mechanism.

Using delay function
In this option, the sequencer network does not calculate the VRF data. The pseudorandom value passed to the contract is calculated as follows:

  • The VDF (Verifiable Delay Function) value is computed from the hash of the Cosmos block.
  • The calculated value is concatenated with the interaction ID.
  • The hash is then computed from this concatenation.

The computation of the delay function should be long enough that the proposer has no chance of computing it. Therefore, they cannot manipulate the block creation process based on the result.
Note: The timeout for the proposer increases after each round in which block production fails. The delay function must take this into account.

The pseudorandom value would be calculated off-chain. We could create a service that calculates these values and provides them to the DRE nodes or SDK.

Using a hash chain with Arweave can also be considered.

➕ It does not complicate the sequencing process.
➖ The calculation of states for contracts that require pseudorandomness occurs with a certain delay due to VDF.

Using hashes of future blocks
The pseudorandom value for a given block is calculated based on a sequence of hashes of blocks that follow the current block. This sequence must be long enough so that the proposers of those blocks have at least 1/3 of the votes. This ensures that not all the hashes were chosen by malicious nodes.

➕ A relatively simple solution.
➖ The length of the sequence will increase with the number of validators. Initially, it may only be a few blocks, but as the network grows, the delay (sequence length) will also increase.

@szynwelski
Copy link
Contributor Author

Note: Example of implementation of VRF in Go: https://github.com/warp-contracts/sequencer/blob/test2/tagHelper/tags.go#L97

@szynwelski
Copy link
Contributor Author

szynwelski commented May 24, 2023

@ppedziwiatr @jakub-wojciechowski @janekolszak
The above scenarios are open for discussion. My recommendation: delay function.

@szynwelski szynwelski added this to the First phase milestone Jun 22, 2023
@szynwelski szynwelski self-assigned this Sep 25, 2023
@szynwelski
Copy link
Contributor Author

In addition to the above proposals, there are other approaches that allow for securely generating random values. Each of them has some drawback, for example, a complicated key generation process in the case of threshold signatures or weak performance in other solutions. See: Randomness in Blockchain Protocols for more information.

@szynwelski
Copy link
Contributor Author

In the initial version of the sequencer, a simple method for generating random values (#71) was implemented as follows:

  • For L1 interactions: calculate SHA3-256 from the sort key.
  • For L2 interactions: calculate SHA3-256 from the block hash and the sort key.

This is not a perfect solution as it gives the Proposer limited influence over the generated value. However, it is not worse than the current approach. The goal is to implement a completely unbiased solution in future version of the sequencer.

@szynwelski szynwelski modified the milestones: First phase, Third phase Oct 5, 2023
@szynwelski
Copy link
Contributor Author

API for random numbers available in contracts: warp-contracts/warp#474

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant