Cross-Chain Realitio Proxy

Enables cross-chain arbitration for Realition (Reality.eth) on Polygon using Kleros as arbitrator.

We use Polygon Fx-Portal mechanism for cross chain communication. You can find out more about how Fx-Portal works from here:

High-Level Flow Description

  1. Alice requests arbitration on the main chain paying the arbitration fee to the ETH proxy and indicates the maximum value of the bond for the question (A.K.A. max_previous).
  2. The ETH proxy communicates the request to the Polygon proxy through the Fx-Portal.
  3. The Polygon tries to notify Realitio of the arbitration request and forwards the max_previous value:
    1. If the bond has not changed, the arbitration request will be accepted.
      1. Notify the ETH proxy through the Fx-Portal.
      2. Call the receiveMessage function with Polygon Tx hash on Ethereum
    2. Otherwise, if it changed then:
      1. Notify the ETH proxy through the Fx-Portal.
      2. Call the receiveMessage function with Polygon Tx hash on Ethereum
      3. The ETH proxy refunds Alice. END
  4. In the mean time while Realitio was being notified of the arbitration request, the arbitration fees might have changed:
    1. If the fees stayed the same (most common case) then:
      1. Create a dispute on Kleros Court.
    2. If the fees have decreased then:
      1. Create a dispute on Kleros Court.
      2. Refund Alice of the difference.
    3. If the fees have increased, then the arbitration request will fail:
      1. Refund Alice of the value paid so far.
      2. The ETH proxy notifies the Polygon proxy through the Fx-Portal that the arbitration failed to be created.
      3. The Polygon proxy notifies Realitio of the failed arbitration. END
  5. The Kleros court gives a ruling. It is relayed to the Polygon proxy through the Fx-Portal.
    1. If the ruling is the current answer, Bob, the last answerer, is the winner. END
    2. If it is not, Alice is the winner. END

Relaying Messages from Polygon to Ethereum

Polygon-to-Ethereum communication requires manual intervention, the exact mechanism for it is described here

There is also a fx-tunnel-relayer bot developed by the UMAProtocol for this purpose that can either be used as is or as a reference for our own bot.

Deployed Addresses

See contracts/README.md.

Contributing

Repo Structure

Each directory at the root of this repository contains code for each individual part that enables this integration:

  • bots/: service to automate some steps of the flow which otherwise would required manual intervention from users.
    • Notice: while this is a centralized service, it exists only for convenience. Users can fulfill the role of the bots if they wish to.
  • contracts/: Smart contracts to enable cross-chain arbitration for Realitio (Reality.eth). Learn more.
  • dynamic-script/: allows fetching the dynamic content for the arbitration, as described by ERC-1497: Evidence Standard.
  • evidence-display/: display interface that should be used to render the evidence for arbitrators, as described by ERC-1497: Evidence Standard.