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:
- https://docs.polygon.technology/docs/develop/l1-l2-communication/fx-portal/
- https://github.com/fx-portal/contracts
- 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
). - The ETH proxy communicates the request to the Polygon proxy through the Fx-Portal.
- The Polygon tries to notify Realitio of the arbitration request and forwards the
max_previous
value:- If the bond has not changed, the arbitration request will be accepted.
- Notify the ETH proxy through the Fx-Portal.
- Call the receiveMessage function with Polygon Tx hash on Ethereum
- Otherwise, if it changed then:
- Notify the ETH proxy through the Fx-Portal.
- Call the receiveMessage function with Polygon Tx hash on Ethereum
- The ETH proxy refunds Alice. END
- If the bond has not changed, the arbitration request will be accepted.
- In the mean time while Realitio was being notified of the arbitration request, the arbitration fees might have changed:
- If the fees stayed the same (most common case) then:
- Create a dispute on Kleros Court.
- If the fees have decreased then:
- Create a dispute on Kleros Court.
- Refund Alice of the difference.
- If the fees have increased, then the arbitration request will fail:
- Refund Alice of the value paid so far.
- The ETH proxy notifies the Polygon proxy through the Fx-Portal that the arbitration failed to be created.
- The Polygon proxy notifies Realitio of the failed arbitration. END
- If the fees stayed the same (most common case) then:
- The Kleros court gives a ruling. It is relayed to the Polygon proxy through the Fx-Portal.
- If the ruling is the current answer, Bob, the last answerer, is the winner. END
- If it is not, Alice is the winner. END
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.
See contracts/README.md.
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.